Impedir o Ubuntu de desligar antes que as atualizações automáticas em segundo plano sejam concluídas

21

Eu instalei um (x) Ubuntu 14.04 no PC de um amigo. As atualizações automáticas estão definidas para "baixar e instalar atualizações automaticamente".

O problema é que, após alguns meses de uso, ele sem querer desliga o PC antes que a atualização dos pacotes seja concluída. Isso leva a dependências / pacotes quebrados, o que leva à atualização sendo afetada e à necessidade de executarsudo dpkg --configure -a

É possível fazer o Ubuntu aguardar a conclusão das atualizações antes do desligamento ou reinicialização do PC, como o Windows faz para garantir que nunca haverá pacotes quebrados e que o PC permaneça atualizado automaticamente?

Giannis
fonte
Você deixou seu PC afk enquanto atualizava ?. Verifique seuSystem Settings -> Power
BeGood
1
O que você acha que está causando os desligamentos? Um sistema operacional não deve ser desligado aleatoriamente por conta própria, pois isso também seria um risco de perda de dados. Ele está talvez pressionando o botão liga / desliga ou cortando a rede?
thomasrutter
Não desliga aleatoriamente. É uma escolha do usuário. Mas depois de muitos meses de uso, ele acontece para desligar o PC quando a atualização ainda está em andamento
Giannis
Estou em um vínculo semelhante, mas pior, quando disse ao meu servidor para reiniciar durante uma dist-upgrade que eu havia iniciado manualmente (e esquecido). Está claro que ele estava no meio da atualização do grub, então agora eu preciso consertar isso (não é impossível, mas estou feliz que este não seja um sistema que eu realmente preciso estar em execução no momento).
LovesTha
Estou escrevendo um script bash para tentar fazer isso, vou publicá-lo quando terminar.
cat

Respostas:

8

Molly-Guard é um programa exatamente para esse fim; requer que você faça uma pequena quantidade de configuração e tenha /usr/sbin antes /sbin na sua $PATH.

Caso contrário, de acordo com isso, os detalhes exatos são altamente dependentes da implementação da GUI / DE. Como sabemos que seu amigo está usando o Xubuntu, isso o restringe, mas sem recompilar o Xfce com esse suporte embutido (o que criaria outros problemas), parece muito difícil.

De acordo com minha pesquisa abundante, você pode, teoricamente, substituir /sbin/shutdownpor um script que verifique se um trabalho apt está ativo e é executado sudo shutdown -cou sudo init 2para cancelar um desligamento em execução e waitsair, mas não tenho certeza de quão robusto isso seja.

De acordo com isso , você pode dificultar o desligamento do usuário , em vez de conectar um script.

Por fim, conforme descrito aqui , você pode instalar unattended-upgradessobre qualquer sistema que esteja usando para atualizações automáticas agora e verifique se ele sai antes do desligamento, conforme detalhado nesta resposta .


Existem muitas opções, todas com níveis variáveis ​​de confiabilidade, mas acho que a melhor, que resolve o que penso ser, até certo ponto, um problema X / Y subjacente em jogo aqui, é esta:

Use crontabpara fazer o computador dele funcionar dpkg --configure -aa cada inicialização.

@ LovesTha: Para o seu propósito, eu recomendo unattended-upgrades, ou talvez Molly-Guard.

gato
fonte
1
Molly guarda não é tão impressionante para mim, eu normalmente desligo esta caixa pressionando o botão liga / desliga. opções de atualização autônoma parecem razoáveis, espero que funcione.
precisa saber é o seguinte
7

Introdução

O script abaixo usa polling orientado a interrupção para mensagens específicas do dbus e, sempre que vir solicitação de desligamento / reinicialização, testará se um gerenciador de pacotes como dpkgouapt está em execução. Se eles estiverem em execução, a solicitação de desligamento será cancelada.

Configuração

Como você mencionou que seu amigo não quer tocar na linha de comando, você precisará ssh na máquina dele ou virá e instalará isso manualmente.

Configuração manual

  1. mkdir $HOME/bin
  2. Copie a fonte do script, salve no arquivo chamado preventShutdown.sh
  3. O script deve ser executável. Use chmod +x $HOME/bin/preventShutdown.shpara fazer isso
  4. Adicione um script à lista de rotinas a serem executadas no login no Unity / Gnome usando o aplicativo Startup Applications ou colocando manualmente um .desktoparquivo no$HOME/.config/autostart

Configuração alternativa

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

Adicione o script como um aplicativo de inicialização.

Origem do Script

#! /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
fonte
+1: Isso é exatamente o que eu faria em um script, mas rapidamente percebi que era muito mais complexo do que eu suspeitava originalmente.
cat
5
  1. Para citar Einstein:

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

    portanto, não há 100% de garantia contra a estupidez humana, mas você pode dificultar que os não-Einsteins quebrem as coisas:

  2. Ativando atualizações automáticas ao desligar .

  3. Explique que os computadores não são martelos, nem pregos, mas equipamentos frágeis e inteligentes que precisam de dois tipos de alimentos: eletricidade e atualizações.

Alternativamente,

  1. Pare completamente as atualizações automáticas e comece visitando seu amigo com mais frequência e instale você mesmo as atualizações.
  2. Peça cervejas ou uma boa refeição para "afinar" o computador

Como alternativa:
• use o Remmina para manter as coisas funcionando sem problemas

Fabby
fonte
2
100% concordaram. Ele também pode configurar o ssh e o encaminhamento de portas no roteador para gerenciar remotamente.
Sergiy Kolodyazhnyy
2
Menos sexismo seria bom.
precisa saber é o seguinte
@LovesTha que sexismo?
Fabby
8 horas depois que deixei esse comentário, você editou o post para ser muito menos sexista. Agora, mais de dois anos depois, você está tendo problemas para lembrar o que escreveu originalmente.
LovesTha 22/03
@LovesTha Sim, não é mais sexista ... Hora de remover o comentário. :-)
Fabby