Zapobiegaj zamykaniu systemu Ubuntu przed zakończeniem automatycznych aktualizacji w tle

21

Zainstalowałem (x) Ubuntu 14.04 na komputerze znajomego. Automatyczne aktualizacje są ustawione na „pobieranie i automatyczne instalowanie aktualizacji”.

Problem polega na tym, że po kilku miesiącach użytkowania nieświadomie wyłącza komputer przed zakończeniem aktualizacji pakietów. Prowadzi to do zepsutych zależności / pakietów, co prowadzi do wpływu aktualizacji i konieczności uruchomieniasudo dpkg --configure -a

Czy to możliwe, aby Ubuntu czekał na zakończenie aktualizacji przed zamknięciem komputera lub ponownym uruchomieniem, tak jak robi to system Windows, aby mieć pewność, że nigdy nie zostaną uszkodzone pakiety i że jego komputer pozostanie aktualizowany automatycznie?

Giannis
źródło
Czy pozwoliłeś, aby Twój komputer afkował podczas aktualizacji? Sprawdź swójSystem Settings -> Power
BeGood
1
Jak myślisz, co powoduje zamknięcie systemu? System operacyjny powinien nie tylko sam się losowo wyłączać, ponieważ wiązałoby się to z ryzykiem utraty danych. Czy może naciska przycisk zasilania lub odcina zasilanie?
thomasrutter
Nie wyłącza się losowo. To jest wybór użytkownika. Ale po wielu miesiącach użytkowania zdarza się, że wyłącza komputer podczas aktualizacji
Giannis,
Jestem w podobnej, ale gorszej sytuacji, gdy powiedziałem mojemu serwerowi, aby zrestartował się podczas aktualizacji dist, którą ręcznie rozpocząłem (i zapomniałem). Oczywiste jest, że w tym czasie trwało właśnie aktualizowanie gruba, więc teraz muszę to naprawić (nie jest to niemożliwe, ale cieszę się, że nie jest to system, którego naprawdę potrzebuję.
LovesTha,
Piszę skrypt bash, aby spróbować to zrobić, opublikuję go, gdy skończę.
kot

Odpowiedzi:

8

Molly-Guard to program właśnie w tym celu; wymaga to zrobić niewielką ilość konfiguracji, i /usr/sbin zanim /sbin w twojej $PATH.

W przeciwnym razie, zgodnie z tym dokładne dane są silnie uzależnione od realizacji DE / GUI. Ponieważ wiemy, że twój przyjaciel używa Xubuntu, zawęża to, ale bez ponownej kompilacji Xfce z tym wbudowanym wsparciem (co mogłoby powodować kolejne problemy) wydaje się bardzo trudne.

Zgodnie z moimi szczerymi badaniami teoretycznie możesz po prostu zastąpić /sbin/shutdownskryptem, który sprawdza, czy zadanie apt jest uruchomione i wykonuje się, sudo shutdown -club sudo init 2anuluje trwające zamknięcie i waitkończy działanie, ale nie jestem pewien, jak solidne jest to zadanie.

Zgodnie z tym , możesz po prostu utrudnić użytkownikowi zamknięcie, zamiast podpinania skryptu.

Na koniec, jak tu nakreślono , możesz zainstalować unattended-upgradesna dowolnym systemie, którego używasz teraz do automatycznych aktualizacji, i upewnij się, że kończy działanie przed zamknięciem, jak szczegółowo opisano w tej odpowiedzi .


Istnieje wiele opcji, z których wszystkie są różne poziomy niewiarygodne, ale myślę, że najlepsza, która rozwiązuje to , co moim zdaniem jest do pewnego stopnia leżącym u podstaw problemem X / Y , to:

Służy crontabdo uruchamiania komputera dpkg --configure -aprzy każdym rozruchu.

@LovesTha: Dla twojego celu polecam unattended-upgrades, a może Molly-Guard.

kot
źródło
1
Molly guard nie jest dla mnie aż tak niesamowity, zwykle wyłączam to okno, naciskając przycisk zasilania. opcje nienadzorowanej aktualizacji wyglądają rozsądnie, mam nadzieję, że to działa.
LovesTha
7

Wprowadzenie

Poniższy skrypt używa odpytywania sterowanego przerwaniami dla określonych komunikatów z dbus i za każdym razem, gdy zobaczy żądanie wyłączenia / ponownego uruchomienia, sprawdzi, czy menedżer pakietów, taki jak, dpkgczy aptdziała. Jeśli są uruchomione, żądanie zamknięcia zostanie anulowane.

Ustawiać

Ponieważ wspomniałeś, że twój przyjaciel nie chce dotykać linii poleceń, będziesz musiał albo ssh na jego maszynie, albo przyjść i zainstalować to ręcznie.

Manualna instalacja

  1. mkdir $HOME/bin
  2. Skopiuj źródło skryptu i zapisz w pliku o nazwie preventShutdown.sh
  3. Skrypt musi być wykonywalny. Użyj, chmod +x $HOME/bin/preventShutdown.shaby to zrobić
  4. Dodaj skrypt do listy procedur uruchamianych podczas logowania do Unity / Gnome przy użyciu aplikacji startowych lub ręcznie umieszczając .desktopplik w$HOME/.config/autostart

Alternatywna konfiguracja

sudo apt-get install git
cd /opt
sudo git clone https://github.com/SergKolo/sergrep.git
sudo chmod +x /opt/sergrep/*

Dodaj skrypt jako aplikację startową.

Źródło skryptu

#! /bin/bash

##########################
# AUTHOR: Serg Kolo 
# Date: Saturday, December 26th, 2015
# Description: Script to notify user and prevent 
#   shutdown or reboot
#   if any update or package manager
#   are running. 
# TESTED ON: 14.04.3 LTS, Trusty Tahr
# WRITTEN FOR: http://askubuntu.com/q/702156/295286
# VERSION: 2, removed xdotool, using dbus method
#          changed to C-style of organizing code
#########################

# Copyright (c) 2015 Serg Kolo
#
# Permission is hereby granted, free of charge, to any person obtaining a copy
# of this software and associated documentation files (the "Software"), to deal in 
# the Software without restriction, including without limitation the rights to use,
# copy, modify, merge, publish, distribute, sublicense, and/or sell copies of 
# the Software, and to permit persons to whom the Software is furnished to do so, 
# subject to the following conditions:
#
# The above copyright notice and this permission notice shall be included in all 
# copies or substantial portions of the Software.
#
# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, 
# INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A 
# PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT 
# HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION 
# OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE 
# SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.

# Uncomment the line bellow if needed for debugging
# set -x
###########################
# VARIABLES
###########################

DISPLAY=:0 # has to be set since we are using notify-send


###########################
# MAIN
###########################
#
#    Basic idea : This runs dbus-monitor which waits for
# "RebootRequested" memberf from com.canonical.Unity.Session ,
# which apprears only when the user clicks the shutdown option 
# from the Unity's top right drop down box. Why RebootRequested ?
# Because this message is guaranteed to pop up once user presses
# the shutdown button.
#   The while loop with read command does the big job.
# dbus-monitor sends initial message , so we want to filter only
# The output that contains the string we need, hence the case...esac
# structure employed here. Once we get the proper message.
# we check whether update-manager or package managers are running
# If there is one instance, then call CancelAction method
# and send notification to the user.
#   Both dbus-monitor and while loop run continuously. This
# can be launcher as script in `/etc/rc.local` or `/etc/rc2.d`
# or preferably (!) in `/etc/xdg/autostart/` . 
#   Here is sample /etc/xdg/autostart/preventShutdown.desktop file
# 
# [Desktop Entry]
# Type=Application
# Name=Prevent-Update
# Exec=/home/$USER/bin/preventShutdown.sh
# OnlyShowIn=GNOME;Unity;
# Terminal=false
# 
# Remember to make this file  as well as script be root-owned with 
# chmod +x /path/to/Script.
# It is preferred to store the script in user's personal $HOME/bin
# folder.
# Make sure to edit $HOME/.profile file to include that into $PATH
# variable

interupt()
{
 qdbus com.canonical.Unity /com/canonical/Unity/Session com.canonical.Unity.Session.CancelAction
 notify-send "<<< UPDATE IN PROGRESS; DO NOT SHUT DOWN>>>"
 wall <<< "<<< UPDATE IN PROGRESS; DO NOT SHUT DOWN>>>"
}

main()
{
 dbus-monitor --profile "interface='com.canonical.Unity.Session',type=signal" |
 while read -r line;
 do
  case "$line" in
   *RebootRequested*)
       pgrep update-manager || pgrep apt-get || pgrep dpkg
    if [ $? -eq 0 ]; then
           interupt
        fi
     ;;
   esac
 done
}

main
Sergiy Kolodyazhnyy
źródło
+1: Właśnie to zamierzałem zrobić w skrypcie, ale szybko zdałem sobie sprawę, że był on o wiele bardziej złożony, niż początkowo podejrzewałem.
kot
5
  1. Cytując Einsteina:

    Only two things are infinite, the universe and human stupidity, 
    and I'm not sure about the former.
    

    więc nie ma 100% gwarancji na ludzką głupotę, ale możesz utrudnić nie-Einsteinom rozbicie rzeczy poprzez:

  2. Aktywacja automatycznych aktualizacji przy zamykaniu .

  3. Wyjaśnij, że komputery nie są młotami ani gwoździami, ale kruche, inteligentne urządzenia, które potrzebują dwóch rodzajów żywności: elektryczności i aktualizacji.

Alternatywnie,

  1. Całkowicie zatrzymaj automatyczne aktualizacje i zacznij od częstszego odwiedzania znajomego i sam zainstaluj aktualizacje dla niego.
  2. Poproś o piwo lub smaczny posiłek, aby „dostroić” komputer

Alternatywnie:
• użyj Remminy, aby utrzymać płynność działania

Fabby
źródło
2
100% uzgodnione. Mógł także skonfigurować ssh i przekierowywanie portów na routerze, aby zarządzać nim zdalnie.
Sergiy Kolodyazhnyy
2
Przydałby się mniejszy seksizm.
LovesTha
@LovesTha jaki seksizm?
Fabby
8 godzin po tym, jak zostawiłem ten komentarz, zredagowałeś post, aby być o wiele mniej seksistowskim. Teraz, ponad dwa lata później, masz problem z przypomnieniem sobie tego, co napisałeś.
LovesTha
@LovesTha Tak, już nie seksistowskie ... Czas usunąć komentarz. :-)
Fabby