patternbashMinor
Simple Linux upgrade script in Bash
Viewed 0 times
scriptsimplebashlinuxupgrade
Problem
As I will be deploying this script on multiple machines with the very same system Linux Mint 18 with rather same configuration, I would like to be semi-sure I won't screw things up much. This little script will run every day from
Conditions were:
My current idea is simple:
Current visual output:
crontab and will be logged into syslog.Conditions were:
- Code Readability
- Output Readability
- Colored Headings
- Attempt to correct things
- Clean-up after update
My current idea is simple:
#!/bin/bash
RED="\033[1;31m"
GREEN="\033[1;32m"
NOCOLOR="\033[0m"
echo
echo -e "step 1: ${GREEN}pre-configuring packages${NOCOLOR}"
sudo dpkg --configure -a
echo
echo -e "step 2: ${GREEN}fix and attempt to correct a system with broken dependencies${NOCOLOR}"
sudo apt-get install -f
echo
echo -e "step 3: ${GREEN}update apt cache${NOCOLOR}"
sudo apt-get update
echo
echo -e "step 4: ${GREEN}upgrade packages${NOCOLOR}"
sudo apt-get upgrade
echo
echo -e "step 5: ${GREEN}distribution upgrade${NOCOLOR}"
sudo apt-get dist-upgrade
echo
echo -e "step 6: ${GREEN}remove unused packages${NOCOLOR}"
sudo apt-get --purge autoremove
echo
echo -e "step 7: ${GREEN}clean up${NOCOLOR}"
sudo apt-get autoclean
echoCurrent visual output:
Solution
The output of your script is lovely, but it strikes me as a work in progress. There's nothing wrong with what is there, but it seems a few major pieces are missing.
error checking
What happens if one of the steps fails? As it stands the script will diligently proceed to the next step. If you actually checked the return codes from your
logging
You mention logging, but there is no such thing in the script. Adding this would not be hard. If you want your messages to go to the screen and a log you could add functions that log and write to the screen.
docs
Shouldn't there be docs somewhere? A link to a wiki page or something in the script would help folks figure out what is up. Providing help from within the script if a
rewrite based on above
finally
It is a good habit to run your scripts through shellcheck.net. Even my short rewritten example has one thing that could be improved.
error checking
What happens if one of the steps fails? As it stands the script will diligently proceed to the next step. If you actually checked the return codes from your
apt commands you would also get a chance to use the RED color that seemed wasted in the comments above.logging
You mention logging, but there is no such thing in the script. Adding this would not be hard. If you want your messages to go to the screen and a log you could add functions that log and write to the screen.
logger is handy way to add to the system logs, but you could write to your own $LOGFILE too with something likeecho "step $STEP: $MSG" >> $LOGFILEdocs
Shouldn't there be docs somewhere? A link to a wiki page or something in the script would help folks figure out what is up. Providing help from within the script if a
-h is provided is a good habit to get into.rewrite based on above
#!/bin/bash
RED="\033[1;31m"
GREEN="\033[1;32m"
NOCOLOR="\033[0m"
mylog() {
STEP=$1
MSG=$2
echo -e "step $STEP: ${GREEN}${MSG}${NOCOLOR}"
logger "step $STEP: $MSG"
}
myfail() {
STEP=$1
MSG=$2
echo -e "step $STEP ERROR: ${RED}${MSG}${NOCOLOR}"
logger "step $STEP ERROR: $MSG"
}
# handle command line options
if [[ $1 == "-h" ]]; then
echo "usage: $0"
echo " -h prints help"
exit 1
fi
# step 1
mylog 1 "the start"
echo foo
# step 2
mylog 2 "a middle"
echo bar
# step 3
mylog 3 "the end"
echo baz
if [[ $? == 0 ]]; then
myfail 3 "nothing really"
fifinally
It is a good habit to run your scripts through shellcheck.net. Even my short rewritten example has one thing that could be improved.
Code Snippets
echo "step $STEP: $MSG" >> $LOGFILE#!/bin/bash
RED="\033[1;31m"
GREEN="\033[1;32m"
NOCOLOR="\033[0m"
mylog() {
STEP=$1
MSG=$2
echo -e "step $STEP: ${GREEN}${MSG}${NOCOLOR}"
logger "step $STEP: $MSG"
}
myfail() {
STEP=$1
MSG=$2
echo -e "step $STEP ERROR: ${RED}${MSG}${NOCOLOR}"
logger "step $STEP ERROR: $MSG"
}
# handle command line options
if [[ $1 == "-h" ]]; then
echo "usage: $0"
echo " -h prints help"
exit 1
fi
# step 1
mylog 1 "the start"
echo foo
# step 2
mylog 2 "a middle"
echo bar
# step 3
mylog 3 "the end"
echo baz
if [[ $? == 0 ]]; then
myfail 3 "nothing really"
fiContext
StackExchange Code Review Q#146896, answer score: 5
Revisions (0)
No revisions yet.