コマンドラインで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/

4
これは素晴らしいです。欠けているのは、コマンドを実行した人だけです。
限定A

3
@LimitedAtonement /var/log/auth.logをご覧ください。インストールを実行しているユーザー含まれている場合があります。(ルートとして実行されているシェル/プログラムを介してインストールが呼び出された場合、これは役に立ちません)
-Lekensteyn

3
また有用:zgrep、zcat
ishmael

このファイルは、元のapt-getの結果としてインストールされた依存関係パッケージも記録しますか?
マヘシャ999

2
@PTアップグレード」
マイケルトンネル

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両方の場合に使用して、パッケージのような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 16

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='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)
弊社のサイトを使用することにより、あなたは弊社のクッキーポリシーおよびプライバシーポリシーを読み、理解したものとみなされます。
Licensed under cc by-sa 3.0 with attribution required.