Risposte:
/ var / log / apt contiene una cronologia delle installazioni di pacchetti. Tuttavia, per impostazione predefinita, è gestito da logrotate
quale comprime e invecchia le voci precedenti.
In alternativa alla risposta di Lgarzo, puoi fare grep
ciò che ti interessa /var/log/dpkg.log
. Ad esempio, se vuoi vedere tutto ciò che hai installato o aggiornato ieri, puoi eseguire:
cat /var/log/dpkg.log | grep "^2012-03-25.*\ installed\ "
Una cosa da notare: questo elencherà anche i pacchetti installati manualmente ( sudo dpkg -i ...
), che non compariranno nella cronologia di apt.
Anche meglio usare zgrep se è installato in modo da poter trovare linee anche nei file gzipped
zgrep "^2012-03-25.*\ installed\ " /var/log/dpkg.log*
Ora è possibile farlo anche tramite il centro software! Vai su Cronologia e puoi visualizzare tutti gli aggiornamenti e le installazioni.
Ci è stato utile avere una risposta leggermente più semplice e accurata alla domanda "quando è stata l'ultima volta che abbiamo patchato questa cosa?". Quindi ho messo insieme questo. L'ho provato su 12.04 e 14.04 e 16.04. Restituisce risposte ragionevolmente accurate per quella domanda. Nota: "ragionevolmente preciso" probabilmente non è "completamente accurato". Nota: solo "per quella domanda".
uscita campione:
xenial% 9: ./linuxpatchdate
2016-07-19 54
2017-02-24 363
2017-03-08 7
2017-03-09 2
subroutine e programma:
#!/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";
}