Answers:
作为lgarzo答案的替代方法,您可以从中找到grep
您感兴趣的东西/var/log/dpkg.log
。例如,如果您想查看昨天安装或升级的所有内容,则可以运行:
cat /var/log/dpkg.log | grep "^2012-03-25.*\ installed\ "
需要注意的一件事:这还将列出手动安装的软件包(sudo dpkg -i ...
),该软件包不会显示在apt的历史记录中。
最好使用zgrep(如果已安装),以便您也可以在gzip压缩文件中找到行
zgrep "^2012-03-25.*\ installed\ " /var/log/dpkg.log*
现在也可以通过软件中心来执行此操作!转到历史记录,您可以显示所有更新和安装。
对我们“何时最后一次修补此问题?”这个问题提供一个稍微简单和准确的答案对我们很有用。所以我把这放在一起。我在12.04、14.04和16.04上进行了测试。它为该问题返回合理准确的答案。注意:“合理准确”可能不是“完全准确”。注意:仅“针对该问题”。
样本输出:
xenial% 9: ./linuxpatchdate
2016-07-19 54
2017-02-24 363
2017-03-08 7
2017-03-09 2
子程序和程序:
#!/usr/bin/perl
#------------------ subroutines --------------------
sub parseRecord {
my $sdate = "";
my $useful = 0;
my $packages = 0;
my @ptmp;
while (my $recordLine = shift() ) {
if ($recordLine =~ m/^Start-Date: ([\d\-]*).*/) {
$sdate = $1;
}
elsif ($recordLine =~ m/^Commandline:.*upgrade/) {
$useful = 1;
}
elsif ($recordLine =~ m/^Install: (.*)/) {
$recordLine =~ s/\([^\)]*\)//g;
@ptmp = split(/,/,$recordLine);
$packages = $packages + $#ptmp + 1;
}
elsif ($recordLine =~ m/^Upgrade: (.*)/) {
$recordLine =~ s/\([^\)]*\)//g;
@ptmp = split(/,/,$recordLine);
$packages = $packages + $#ptmp + 1;
}
}
if ($useful) {
return ($sdate,$packages);
}
else {
return ("0",0);
}
}
#------------------ main program --------------------
@lines = split(/\n/,`/bin/zcat -f /var/log/apt/history.log /var/log/apt/history*gz`);
my %patchHash;
my $line;
my @inputLines;
my $pushDate = "";
my $pushNum = "";
foreach $line (@lines) {
# all records separated by blank lines
if ($line !~ /./) {
# no-op
}
elsif ($line =~ m/^Start-Date: ([\d\-]*).*/) {
@inputLines = ();
push (@inputLines, $line);
}
elsif ($line =~ m/^End-Date: ([\d\-]*).*/) {
($pushDate, $pushNum) = parseRecord(@inputLines);
if ($pushNum != 0) {
$patchHash{$pushDate} += $pushNum;
}
}
else {
push (@inputLines, $line);
}
}
foreach $pushDate (sort(keys(%patchHash))) {
print "$pushDate $patchHash{$pushDate}\n";
}