Find last time update was performed with apt-get
Solution 1
At least in Ubuntu systems there is a file /etc/apt/apt.conf.d/15update-stamp containing:
APT::Update::Post-Invoke-Success {"touch /var/lib/apt/periodic/update-success-stamp 2>/dev/null || true";};
So see if you have /var/lib/apt/periodic/update-success-stamp and if you have it, you can use
stat -c %y /var/lib/apt/periodic/update-success-stamp
command to get the the time of the last "apt-get update" invocation.
And if your system does not have that apt configuration file, you can always add it.
Solution 2
An apt-get update
may not create or update files, it does update the cache directory so we can use that to get the timestamp when the last apt-get update
was run :
stat -c %Y /var/cache/apt/
Solution 3
You could check the Access times on the files in /var/lib/apt/lists which is updated when you run apt-get update. If apt-get update was run with sudo you should have a line logged in /var/log/auth.log when it was done..
Solution 4
Don't go from the lock files. Lock files aren't reliable, they tend to move around over time with new Linux releases, and many programs cleanup (remove) lock files when they're done with them.
The following command will get you what you're looking for.
ls -lt --time-style="long-iso" /var/log/apt | grep -o '\([0-9]\{2,4\}[- ]\)\{3\}[0-9]\{2\}:[0-9]\{2\}' -m 1
This is two commands in one. The results of the first command filter into the second through the pipe (|) symbol.
In the first command, I'm using "ls" to list the file contents of the /var/log/apt directory, which is the directory that stores the access history logs for apt-get. The "-lt" part is actually two switches. The first "l" switch tells "ls" to list one file per line with detail. The second "t" switch tells "ls" to sort by date and time. "--time-style" forces the date time to display in the format "YYYY-MM-DD HH:MM".
In the "grep" portion of the command, the "-o" switch tells grep to only show the portions of each line that match the regular expression exactly. The regular expression I've used here detects date times that are in the format specified in the "ls" command. You'll also notice the true little piece of magic on the very end of the "grep" command that there's a "-m" switch with the number "1" immediately following. This tells "grep" to stop looking for matches after it finds the first one.
So, in summary, we're listing the apt log file details so we can see the last modified date, we then sort by date and tell grep to pull the first date off the top, which it then returns. That's the last date that apt-get ran.
To play devil's advocate for a moment, however, it's common for Debian platforms like Ubuntu to schedule apt-get as a job that runs regularly. If you're looking for the person at the other end of the apt-get execution, you may actually find a machine. You could always match up access logs with the apt logs to see if any time stamps coincide. It's also possible to look at a user's command history to an extent.
Hope this helps!
Solution 5
I suspect you can check the last modified times on files /var/cache/apt to figure out when the last updates were applied to the package lists.
I just tested this, and ran "sudo apt-get update" twice in a row, and the dates did not change from their current value, but I suspect this is because there were no new updates to apply, and that the caches are up to date.
Related videos on Youtube
Mark Roddy
Updated on September 17, 2022Comments
-
Mark Roddy over 1 year
I need to find the last time that the
apt-get update
command was run on my server. How can I determine this information?
-
David Pashley almost 15 yearsAs pointed out somewhere else, you may find some files aren't updated and therefore haven't been downloaded again. This is fine if you want to know how up to date your package lists are, but not if you want to know when apt-get update was last run. The former is more likely.
-
pdwalker over 13 yearsSujoy, Wrapping it in a script is not practical if you have hundreds of servers, and you do not wish to maintain yet another script that might cause problems the next time you update your apt-get package. I think the requestor is looking for an answer that makes use of information already existing in his computer.
-
Alex over 11 yearsUnfortunately not working. In
/var/log/apt
it is also logged when I for example do anapt-get install some-package
. Actually on Ubuntu it does not log something when I doapt-get update
-
Ronny Andersson over 8 yearsAnswer is incomplete. What is
info
andisEmptyString
? Also,info
is a poor choice of function name since that is also a command. Other than that, nice solution! -
Nam Nguyen over 8 years@RonnyAndersson , all in this lib: github.com/gdbtek/ubuntu-cookbooks/blob/master/libraries/…
-
GnP over 7 yearsNote that package installation may also update the cache directory. This is not a reliable check for
apt-get update
-
GnP over 7 years+1 for including the apt.conf line. On ubuntu 14.04 it seems the file is at
/var/lib/apt/periodic/update-stamp
-
fcm over 3 yearsOn my debian
stat -c %y /var/lib/apt/lists/partial
do the trick. File update-success-stamp doesn't exist. -
m1m1k over 2 yearsworked for me, thank you!
-
m1m1k over 2 yearsunfortunately -- this seems to get updated when doing a
apt-get upgrade --dry-run