Come posso mostrare la cronologia della gestione dei pacchetti di apt-get tramite riga di comando?


Risposte:


131

Tutte le azioni con apt (apt-get) vengono registrate. Questi file sono disponibili in / var / log / apt /. Per visualizzare il registro cronologico più recente, eseguire:

less /var/log/apt/history.log

Questi registri vengono ruotati (ogni mese immagino), i vecchi file verranno suffissati con un numero e compressi. Quindi, per visualizzare il registro cronologico successivo, utilizzare:

zless /var/log/apt/history.log.1.gz

Per visualizzare i registri disponibili:

ls -la /var/log/apt/

4
Questo è eccellente L'unica cosa che manca è chi ha eseguito i comandi.
Espiazione limitata

3
@LimitedAtonement Dai un'occhiata a /var/log/auth.log, potrebbe contenere l'utente che esegue l'installazione. (questo non aiuta se l'installazione è stata invocata tramite una shell / programma in esecuzione come root)
Lekensteyn,

3
Utile anche: zgrep, zcat
ishmael,

questo file registra anche i pacchetti di dipendenze installati come risultato di apt-get originale?
Mahesha999,

2
@LimitedAtonement le ultime versioni di APT offrono una parte "Richiesto da:" del log per mostrare chi ha invocato il comando e quale comando hanno invocato come "Commandline: packagekit role = 'update-pacchetti'" o "Commandline: apt upgrade "
Michael Tunnell il

21

Puoi anche eseguire un breve comando per visualizzare il contenuto interessante.

  • Aggiungi questa funzione personalizzata al tuo ~/.bashrc:

    ### pars for fun: install | remove | rollback
    function apt-history(){
    
          case "$1" in
            install)
                  grep 'install ' /var/log/dpkg.log
                  ;;
            upgrade|remove)
                  grep $1 /var/log/dpkg.log
                  ;;
            rollback)
                  grep upgrade /var/log/dpkg.log | \
                      grep "$2" -A10000000 | \
                      grep "$3" -B10000000 | \
                      awk '{print $4"="$5}'
                  ;;
            *)
                  cat /var/log/dpkg.log
                  ;;
          esac
    }
    
  • E chiamalo in un terminale come questo:

    kreso@h17:~$ apt-history install
    2013-08-06 14:42:36 install gir1.2-nautilus-3.0:amd64 <none> 1:3.8.2-0ubuntu1~ubuntu13.04.1
    2013-08-06 14:42:36 install python-nautilus:amd64 <none> 1.1-3ubuntu1
    2013-08-06 14:42:37 install insync-nautilus:all <none> 1.0.20
    2013-08-07 14:41:37 install powertop:amd64 <none> 2.1-0ubuntu1
    2013-08-07 18:44:10 install libdiscid0:amd64 <none> 0.2.2-3build1
    2013-08-07 18:44:11 install sound-juicer:amd64 <none> 3.5.0-0ubuntu1
    

Tratto da qui


zgrep ... /var/log/dpkg.log*- genera voci anche dagli archivi.
Ctrl-C,

6

È inoltre possibile utilizzare il comando seguente per elencare i pacchetti installati di recente

grep "\ install\ " /var/log/dpkg.log

1
ancora meglio: grep "\ install\ " /var/log/apt/history.lognel caso in cui sia necessario copiare e incollare un elenco in apt-get
mchid

2

Se vuoi quei pacchetti che sono stati installati e non successivamente disinstallati, prova questo:

comm -23 <(grep "apt-get install" /var/log/apt/history.log | sed 's/.* //' | sort) \ 
<(grep "apt-get remove" /var/log/apt/history.log | sed 's/.* //' | sort) 

Queste sono le installazioni meno eventuali rimuovenze corrispondenti.

Riferimenti:


+1: Nice one-liner ma valido solo per l'ultimo periodo di rotazione del registro. Inoltre, invece di sort, utilizzare sort -uin entrambi i casi per evitare che vengano visualizzate righe duplicate come in pacchetti simili oracle-java8-installere molti altri.
Cbhihe,

1

Ecco come lo fai effettivamente, diciamo pacchetto mutter:

_P=mutter &&
(cat /var/log/dpkg.log{,.1};zcat /var/log/dpkg.log.*.gz) |
egrep --text "^[^ ]* [^ ]* (configure|install|remove|status [^ ]*|trigproc|upgrade) $_P[: ]" |
sort --reverse | less

L'uso di dpkg.log acquisisce operazioni che apt-get non vede.

Produzione:

2016-12-20 09:47:35 status unpacked mutter:amd64 3.22.2-2ubuntu1~ubuntu16.10.1
2016-12-20 09:47:35 status installed mutter:amd64 3.22.2-2ubuntu1~ubuntu16.10.1
…

1
Si prega di notare che i backtick tripli qui non funzionano come pensi che facciano.
edwinksl,

1

Per ottenere la cronologia degli aggiornamenti di un pacchetto specifico supponendo che sia stato installato / aggiornato tramite apt ecco un oneliner (bash e zgrep), un esempio è per il pacchetto skypeforlinux:

package='skypeforlinux'; pregex="(${package}[^\)]+\))"; while read -r line; do [[ "$line" =~ ^Start-Date:[[:space:]]([[:digit:]].+) ]] && curdate="${BASH_REMATCH[1]} "; [[ "$line" =~ $pregex ]] && echo "$curdate ${BASH_REMATCH[1]}"; done < <(for i in `ls -tr /var/log/apt/history*`; do zgrep -B3 "$package" $i; done)

Questo greps usa i file di registro della cronologia di apt per skypeforlinux comprese le tre righe precedenti per ottenere la data. Quindi scorre il risultato e fa eco alle date e alle versioni pertinenti.

Sostituisci il valore della variabile del pacchetto con il nome del tuo pacchetto, funziona anche con più pacchetti purché inizino con la stessa stringa.

Esempio con output:

package='apache'; pregex="(${package}[^\)]+\))"; while read -r line; do [[ "$line" =~ ^Start-Date:[[:space:]]([[:digit:]].+) ]] && curdate="${BASH_REMATCH[1]} "; [[ "$line" =~ $pregex ]] && echo "$curdate ${BASH_REMATCH[1]}"; done < <(for i in `ls -tr /var/log/apt/history*`; do zgrep -B3 "$package" $i; done)
2017-10-19  15:00:09  apache2-utils:amd64 (2.4.18-2ubuntu3.5)
2017-11-24  14:24:45  apache-pom-java:amd64 (10-2build1, automatic)
2018-02-22  16:42:02  apache2-data:amd64 (2.4.18-2ubuntu3.5, automatic)
2018-02-26  15:34:34  apache2:amd64 (2.4.18-2ubuntu3.5)
2018-02-26  15:36:32  apache2-data:amd64 (2.4.18-2ubuntu3.5)
2018-02-26  15:40:50  apache2-data:amd64 (2.4.18-2ubuntu3.5, automatic)
2018-02-26  15:42:07  apache2:amd64 (2.4.18-2ubuntu3.5)
2018-02-26  15:42:39  apache2:amd64 (2.4.18-2ubuntu3.5)
2018-03-15  10:08:50  apache-pom-java:amd64 (10-2build1)
2018-04-20  08:55:07  apache2-data:amd64 (2.4.18-2ubuntu3.5, 2.4.18-2ubuntu3.8)
2018-07-06  08:55:11  apache2-data:amd64 (2.4.18-2ubuntu3.8, 2.4.18-2ubuntu3.9)
Utilizzando il nostro sito, riconosci di aver letto e compreso le nostre Informativa sui cookie e Informativa sulla privacy.
Licensed under cc by-sa 3.0 with attribution required.