如何通过命令行显示apt-get软件包管理历史记录?


Answers:


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/

4
太好了 唯一缺少的是谁运行了命令。
限量赎罪

3
@LimitedAtonement看看/var/log/auth.log,它可能包含正在运行安装的用户。(如果安装是通过以root用户
身份

3
也有用:zgrep,用zcat
伊斯梅尔

该文件还记录由于原始apt-get而安装的依赖项软件包吗?
Mahesha999 '16

2
@LimitedAtonement APT的最新版本在日志中提供了“ Requested-By:”部分,以显示谁调用了该命令以及他们调用了哪个命令,例如“ Commandline:packagekit role ='update-packages'或“ Commandline:apt”。升级”
Michael Tunnell

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) 

这是安装减去任何匹配的删除。

参考文献:


+1:不错的单线,但仅在最后一个圆木轮换周期内有效。另外sortsort -u在两种情况下都应使用来避免出现重复的行,例如在like 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)

这可以捕获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)
By using our site, you acknowledge that you have read and understand our Cookie Policy and Privacy Policy.
Licensed under cc by-sa 3.0 with attribution required.