Есть ли способ показать историю пакетов, которые были изменены apt-get через командную строку?
Все действия с apt (apt-get) регистрируются. Эти файлы доступны в /var/log/apt/. Чтобы просмотреть самый последний журнал журнала, выполните:
less /var/log/apt/history.log
Эти журналы будут вращаться (я думаю, каждый месяц), старые файлы будут иметь суффикс с номером и сжиматься. Итак, чтобы просмотреть следующий журнал истории, используйте:
zless /var/log/apt/history.log.1.gz
Для просмотра доступных журналов:
ls -la /var/log/apt/
Вы также можете выполнить короткую команду для отображения интересного контента.
-
Добавьте эту пользовательскую функцию в свой
~/.bashrc
:### pars for fun: install | remove | rollbackfunction 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}
-
И вызовите его в терминале, подобном этому:
kreso@h17:~$ apt-history install2013-08-06 14:42:36 install gir1.2-nautilus-3.0:amd64 <none> 1:3.8.2-0ubuntu1~ubuntu13.04.12013-08-06 14:42:36 install python-nautilus:amd64 <none> 1.1-3ubuntu12013-08-06 14:42:37 install insync-nautilus:all <none> 1.0.202013-08-07 14:41:37 install powertop:amd64 <none> 2.1-0ubuntu12013-08-07 18:44:10 install libdiscid0:amd64 <none> 0.2.2-3build12013-08-07 18:44:11 install sound-juicer:amd64 <none> 3.5.0-0ubuntu1
Взято из здесь
Вы также можете использовать следующую команду для получения списка недавно установленных пакетов
grep "\ install\ " /var/log/dpkg.log
Если вы хотите, чтобы те пакеты, которые были установлены и нет после удаления попробуйте выполнить следующее:
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)
Это установки за вычетом любых соответствующих удалений.
Рекомендации:
Чтобы получить историю обновлений определенного пакета, предполагая, что он был установлен / обновлен с помощью apt, вот oneliner (bash и zgrep), пример для пакета 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)
Это greps файлы журнала истории apt для skypeforlinux, включая предыдущие три строки, чтобы получить дату. Затем повторяет результат и повторяет соответствующие даты и версии.
Замените пакет значение переменной с именем вашего пакета работает даже для нескольких пакетов при условии, что они начинаются с одной и той же строки.
Пример с выводом:
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)
Вот как вы на самом деле это делаете, скажем, package 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
С помощью dpkg.log фиксирует операции, которые apt-get не видит.
Выход:
2016-12-20 09:47:35 status unpacked mutter:amd64 3.22.2-2ubuntu1~ubuntu16.10.12016-12-20 09:47:35 status installed mutter:amd64 3.22.2-2ubuntu1~ubuntu16.10.1…