コマンドライン経由で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 <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
here から取得
次のコマンドを使用して、最近インストールしたパッケージを一覧表示することもできます
grep "\ install\ " /var/log/dpkg.log
これらのパッケージをインストールしてnotアンインストールしたい場合は、これを試してください:
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)
これは、インストールから一致する削除を差し引いたものです。
参照:
パッケージのつぶやきは次のようになります。
_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)
これは、日付を取得する前の3行を含むskypeforlinuxのaptの履歴ログファイルを読みます。次に、結果を反復処理し、関連する日付とバージョンをエコーします。
package変数値をパッケージ名に置き換えます。同じ文字列で始まる複数のパッケージでも機能します。
出力の例:
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)