Как показать apt-get историю управления пакетами через командную строку?

Ответы:

131

Все действия с 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/
Lekensteyn
источник
4
Это отлично. Единственное, чего не хватает, это кто управлял командами.
Ограниченное искупление
3
@LimitedAtonement Взгляните на /var/log/auth.log, он может содержать пользователя, выполняющего установку. (это не поможет, если установка была запущена через оболочку / программу, запущенную от имени пользователя root)
Lekensteyn
3
Также полезно: zgrep, zcat
ishmael
этот файл также регистрирует пакеты зависимостей, установленные в результате оригинального apt-get?
Mahesha999
2
@LimitedAtonement последние версии APT предлагают часть журнала «Requested-By:», чтобы показать, кто вызвал команду, а также какую команду они вызвали, например «Командная строка: packagekit role = 'update-packages'» или «Командная строка: apt Обновление "
Майкл Туннелл
21

Вы также можете сделать короткую команду для отображения интересного контента.

  • Добавьте эту пользовательскую функцию к вашему ~/.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
    }
    
  • И назовите это в терминале как это:

    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
    

Взято отсюда

Кресимир Пендик
источник
zgrep ... /var/log/dpkg.log*- выводит записи из архивов тоже.
Ctrl-C
6

Вы также можете использовать следующую команду для просмотра списка недавно установленных пакетов

grep "\ install\ " /var/log/dpkg.log
Деста Хайлеселасси Хагос
источник
1
еще лучше: grep "\ install\ " /var/log/apt/history.logесли вам нужно скопировать и вставить список в apt-get
mchid
2

Если вы хотите, чтобы те пакеты были установлены, а не удалены, попробуйте это:

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) 

Это установка минус любое соответствующее удаление.

Рекомендации:

hoffmanc
источник
+1: хорошая однострочная, но действительна только в течение последнего периода ротации бревен. Кроме того, вместо этого sortиспользуйте sort -uв обоих случаях, чтобы избежать появления повторяющихся строк, например в пакете, как oracle-java8-installerи во многих других.
Cbhihe
1

Вот как вы на самом деле это делаете, скажем, бормотание пакета:

_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.1
2016-12-20 09:47:35 status installed mutter:amd64 3.22.2-2ubuntu1~ubuntu16.10.1
…
Харальд Руделл
источник
1
Обратите внимание, что тройные кавычки здесь не работают так, как вы думаете.
edwinksl
1

Чтобы получить историю обновлений определенного пакета, предполагая, что он был установлен / обновлен через 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)
kilgor
источник