Respostas:
Como alternativa à resposta da lgarzo, você pode encontrar o grep
que lhe interessa /var/log/dpkg.log
. Por exemplo, se você quiser ver tudo o que instalou ou atualizou ontem, você pode executar:
cat /var/log/dpkg.log | grep "^2012-03-25.*\ installed\ "
Uma coisa a notar: isso também listará pacotes instalados manualmente ( sudo dpkg -i ...
), que não aparecerão no histórico do apt.
Melhor ainda, use o zgrep se estiver instalado, para que você possa encontrar linhas nos arquivos compactados em gzip também
zgrep "^2012-03-25.*\ installed\ " /var/log/dpkg.log*
Agora é possível fazer isso também através do centro de software! Vá para Histórico e você pode exibir todas as suas atualizações e instalações.
Tornou-se útil termos uma resposta um pouco mais fácil e precisa para a pergunta "quando foi a última vez que corrigimos esse problema?". Então eu juntei isso. Eu testei em 12.04 e 14.04 e 16.04. Ele retorna respostas razoavelmente precisas para essa pergunta. Nota: "razoavelmente preciso" provavelmente não é "completamente preciso". Nota: apenas "para essa pergunta".
saída de amostra:
xenial% 9: ./linuxpatchdate
2016-07-19 54
2017-02-24 363
2017-03-08 7
2017-03-09 2
sub-rotinas e programa:
#!/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";
}