I have a shell script. A cron job runs it once a day. At the moment it just downloads a file from the web using wget, appends a timestamp to the filename, then compresses it. Basic stuff.
This file doesn’t change very frequently though, so I want to discard the downloaded file if it already exists.
Easiest way to do this?
Thanks!
Do you really need to compress the file ?
wgetprovides-N, --timestampingwhich obviously, turns on time-stamping. What that does is say your file is located at http://www.example.com/file.txtThe first time you do:
The next time it’ll be like this:
Except if the file on the server was updated.
That would solve your problem, if you didn’t compress the file.
If you really need to compress it, then I guess I’d go with comparing the hash of the new file/archive and the old. What matters in that case is, how big is the downloaded file ? is it worth compressing it first then checking the hashes ? is it worth decompressing the old archive and comparing the hashes ? is it better to store the old hash in a txt file ? do all these have an advantage over overwriting the old file ?
You only know that, make some tests.
So if you go the hash way, consider sha256 and xz (lzma2 algorithm) compression.
I would do something like this (in Bash):
and that’s done;