it-swarm.dev

Jak zobrazím historii správy balíků apt-get prostřednictvím příkazového řádku?

Existuje způsob, jak ukázat historii balíčků, které byly změněny apt-get přes příkazový řádek?

125
NES

Všechny akce s apt (apt-get) jsou protokolovány. Tyto soubory jsou k dispozici v adresáři/var/log/apt /. Chcete-li zobrazit nejnovější protokol historie, spusťte:

less /var/log/apt/history.log

Tyto protokoly se střídají (myslím, že každý měsíc), staré soubory budou doplněny číslem a komprimovány. Chcete-li zobrazit další protokol historie, použijte:

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

Zobrazení dostupných protokolů:

ls -la /var/log/apt/
140
Lekensteyn

Můžete také udělat krátký příkaz k zobrazení zajímavého obsahu.

  • Přidejte tuto vlastní funkci do svého ~/.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
    }
    
  • A nazvěte to v terminálu jako je tento:

    [email protected]:~$ 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
    

Převzato z zde

22
Kresimir Pendic

Následující příkaz můžete použít také pro výpis naposledy nainstalovaných balíčků

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

Pokud chcete, aby nainstalované balíčky a nebyly následně odinstalovány, zkuste toto:

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) 

Toto je instalace minus případné odstranění.

Reference:

2
hoffmanc

Chcete-li získat historii aktualizací konkrétního balíčku za předpokladu, že byl nainstalován/aktualizován pomocí apt, je zde oneliner (bash a zgrep), příklad je pro balíček 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)

Toto prohledává soubory protokolu historie apt pro skypeforlinux, včetně předchozích tří řádků, aby se získalo datum. Poté iteruje výsledek a opakuje relevantní data a verze.

Nahraďte proměnnou hodnotu package názvem vašeho balíčku, dokonce funguje pro více balíčků za předpokladu, že začínají stejným řetězcem.

Příklad s výstupem:

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)
2
kilgor

Takto to skutečně děláte, řekněme balíček 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

Použití dpkg.log zachycuje operace, které apt-get nevidí.

Výstup:

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
Harald Rudell