web-dev-qa-db-ja.com

「aptitude」を使用して特定の日付にインストールされたパッケージを表示するにはどうすればよいですか?

aptitude(またはapt-get)を使用しているときに、インストールされたパッケージのリストを日付順にソートする簡単な方法があるかどうか、誰もが知っていますか?

新しいものを試すために、たくさんのパッケージをインストールしましたが、うまくいきませんでした。ディスクスペースを取り戻すために、これらのパッケージをすべて削除したいと思います。

ダウンロードした.debファイルのリストだけを見てみましたが、それは逆方向の方法のように思えます(動作しましたが)。

54
Mikeage

残念ながら、dpkg(パッケージハンドラーaptitudeはその上で動作します)は、パッケージのインストール日を特に保存しませんが、追加することを考えています。ただし、ディレクトリ/var/lib/dpkg/infoに書き込まれたファイルの日付スタンプを見れば、インストール日を見つけることができます。

43
mok0

ログ(/var/log/aptitude)に書き込むようにaptitudeを設定しました。このような出力を生成します。

Aptitude 0.4.11.11: log report
Mon, Feb  9 2009 13:21:28 +0100

IMPORTANT: this log only lists intended actions; actions which fail due to
dpkg problems may not be completed.

Will install 6 packages, and remove 0 packages.
4096B of disk space will be used
===============================================================================
[UPGRADE] apt 0.7.20.1 -> 0.7.20.2
[UPGRADE] apt-utils 0.7.20.1 -> 0.7.20.2
[UPGRADE] base-passwd 3.5.19 -> 3.5.20
[UPGRADE] libgnutls26 2.4.2-5 -> 2.4.2-6
[UPGRADE] libpq5 8.3.5-1 -> 8.3.6-1
[UPGRADE] ucf 3.0015 -> 3.0016
===============================================================================

Log complete.

これにより、aptitudeがインストールした正確な日付とパッケージが表示されます。これを設定するには、aptitudeリファレンスに従います。

Option:Aptitude::Log

Default:/var/log/aptitude

Description: If this is set to a nonempty string, aptitude will log the package
installations, removals, and upgrades that it performs. If the value of
Aptitude::Log begins with a pipe character (ie, ``|''), the remainder of its
value is used as the name of a command into which the log will be piped: for
instance, |mail -s 'Aptitude install run' root will cause the log to be emailed
to root. To log to multiple files or commands, you may set this option to a list
of log targets.

Aptitudeのマニュアルページにaptitudeリファレンスへのリンクがあります。

20
jeremiah

すべてのパッケージのインストール日を確認するsimpleの方法があります。実行するだけです:

grep " install" /var/log/dpkg.log*

その結果、インストールされたすべてのパッケージと正確な日付と時刻のリストが表示されます。

そのソリューションに私を導くコメントをありがとう。

17
jmarceli

これはウェブで見つけました。 dpkgログファイルからdpkgの履歴を作成します。

とてもシンプルに見えます。

function apt-history(){
      case "$1" in
        install)
              cat /var/log/dpkg.log | grep 'install '
              ;;
        upgrade|remove)
              cat /var/log/dpkg.log | grep $1
              ;;
        rollback)
              cat /var/log/dpkg.log | grep upgrade | \
                  grep "$2" -A10000000 | \
                  grep "$3" -B10000000 | \
                  awk '{print $4"="$5}'
              ;;
        *)
              cat /var/log/dpkg.log
              ;;
      esac
}

ソース

編集

このスクリプトをUbuntu 8.10 Serverで試しましたが、非常にうまく機能します。いくつかの情報、問題の解決方法を教えてください。

13
guerda
  • dpkgログを使用

    locate dpkg.log | xargs cat {} | grep " install "
    
  • またはlocateがない場合

    find /var/log/ -name 'dpkg.log' | xargs cat {} | grep " install "
    
  • sortを使用して、適切な時間ベースの順序付けを確保します

    locate dpkg.log | xargs cat {} | grep " install " | sort
    
  • tac(reverse cat)*、headを使用して、最新の4つのエントリを取得するなど

    locate dpkg.log | xargs cat {} | grep " install " | sort | tac | head -n4
    

たとえば、最後のコマンドについては、次のようになります:

2014-10-08 18:56:12 install xorg-server-source:all <none> 2:1.16.1-1
2014-10-08 18:49:34 install libelementary-data:all <none> 0.7.0.55225-1
2014-10-08 18:46:57 install e17:i386 <none> 0.17.6-1
2014-10-08 18:46:56 install libedje-bin:i386 <none> 1.8.6-2.1+b1
5
a20

/var/log/apt/term.log、および古いファイルterm.log.1.gzなどを確認することにより、以前のアクションを追跡することもできます。インストール中のタイムスタンプとメッセージからの完全なログがあります。

4
szarki

実際、これを実行できる「公式」pkginstall.shスクリプトがあります。 公式ドキュメント の指示に従ってください。簡単に言うと、上記のリンクからスクリプトをダウンロードし、実行可能であることを確認してから実行します:

~/pkginstalls.sh

これにより、ホームディレクトリにpkginstalls.txtファイルが作成され、インストールされたすべてのパッケージが日付順にソートされます。

ところで、これはスクリプトの内容です:

#!/bin/bash
#pkginstalls.sh
#creates text file with a list of all packages installed by date

#first append all info from archived logs

i=2
mycount=$(ls -l /var/log/dpkg.log.*.gz | wc -l)
nlogs=$(( $mycount + 1 ))

while [ $i -le $nlogs ]
do
if [ -e /var/log/dpkg.log.$i.gz ]; then
zcat /var/log/dpkg.log.$i.gz | grep "\ install\ " >> $HOME/pkgtmp.txt
fi
i=$(( $i+1 ))

done

#next append all info from unarchived logs

i=1
nulogs=$(ls -l /var/log/dpkg.log.* | wc -l)
nulogs=$(( $nulogs - $nlogs + 1 ))
while [ $i -le $nulogs ]
do
if [ -e /var/log/dpkg.log.$i ]; then
cat /var/log/dpkg.log.$i | grep "\ install\ " >> $HOME/pkgtmp.txt
fi
i=$(( $i+1 ))

done

#next append current log

cat /var/log/dpkg.log | grep "\ install\ " >> $HOME/pkgtmp.txt

#sort text file by date

sort -n $HOME/pkgtmp.txt > $HOME/pkginstalls.txt

rm $HOME/pkgtmp.txt

exit 0
2
Ron

[実際の質問に答える]、はい、apt-getを使用してターミナル内で実行された場合でも、特定の日付にインストールされたパッケージを検索する簡単な方法があります。

Ubuntu Software Centerから自由にインストールできるSynaptic Package Managerをインストールする場合、FILEメニューを開き、「History」オプションを選択するだけです。ここでは、インストールまたは削除された方法に関係なく、追加および削除されたすべてのアプリケーションパッケージのアカウンティングが日付別に整理されています。

2
gyropyge