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

有没有办法显示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 | 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  1:3.8.2-0ubuntu1~ubuntu13.04.1 2013-08-06 14:42:36 install python-nautilus:amd64  1.1-3ubuntu1 2013-08-06 14:42:37 install insync-nautilus:all  1.0.20 2013-08-07 14:41:37 install powertop:amd64  2.1-0ubuntu1 2013-08-07 18:44:10 install libdiscid0:amd64  0.2.2-3build1 2013-08-07 18:44:11 install sound-juicer:amd64  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) 

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

参考文献:

  • comm : https : //stackoverflow.com/a/11963862/338303
  • <(grep...)语法: https : //unix.stackexchange.com/questions/73931/redirecting-multiple-commands-as-input

包嘟嘟说:你实际上是这样做的:

 _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 … 

要获取特定软件包的更新历史记录,假设它是通过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) 

这会为skypeforlinux创建apt的历史日志文件,包括前三行以获取日期。 然后迭代结果并回显相关的日期和版本。

变量值替换为名称,即使它们以相同的字符串开头,也适用于多个包。

输出示例:

 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)