For some purposes you may need to collect the Linux system uptime report once a month.
If so, you can use one of the following bash scripts based on your requirements.
Why should we collect this report?
Restarting the Linux server after a certain period of time is a good practice to fix some pending issues.
It is advisable to restart once in 180 days. But this period may vary depending on your company’s policy.
If you have been running the server for a long time without restarting.
This can lead to some performance issues or memory problems on the server, which I have noticed on many servers.
These scripts provide all system uptime reports in one place.
What is Uptime Command
uptime command will tell how long the system has been running. It gives a one line display of the following information.
The current time, how long the system has been running, how many users are currently logged on, and the system load averages for the past 1, 5, and 15 minutes.
What Is tuptime?
Tuptime is a tool for report the historical and statistical running time of the system, keeping it between restarts. Like uptime command but with more interesting output.
1) Bash Script to Check Linux System Uptime
This bash script will collect all the server uptime and send the report to the given email id.
Please replace your email id instead of ours, otherwise you will not receive mails.
# vi /opt/scripts/system-uptime-script.sh #!/bin/bash upserver=$(for server in `cat /tmp/servers.txt` do nc -zvw3 $server 22 | awk '/succeeded/ {print $3}' done 2>/dev/null) for host in $upserver do echo -n "$host: " ssh $host uptime | awk '{print $3,$4}' | sed 's/,//' done | column -t > /tmp/uptime-report.out cat /tmp/uptime-report.out | mail -s "Linux Servers Uptime Report" "[email protected]"
Set an executable permission to “system-uptime-script.sh” file.
$ chmod +x /opt/scripts/system-uptime-script.sh
Finally run the bash script to get the output.
# sh /opt/scripts/system-uptime-script.sh
You will receive a report like the one below.
# cat /tmp/uptime-report.out 192.168.1.5: 2 days 192.168.1.6: 15 days 192.168.1.7: 30 days 192.168.1.8: 7 days 192.168.1.9: 67 days 192.168.1.10: 130 days 192.168.1.11: 23 days
2) Bash Script to Check If Linux System is Running Over 30 Days
This bash script collects server running over 30 days and sends the report to the given email id. You can change the days according to your needs.
# vi /opt/scripts/system-uptime-script-1.sh #!/bin/bash upserver=$(for server in `cat /tmp/servers.txt` do nc -zvw3 $server 22 | awk '/succeeded/ {print $3}' done 2>/dev/null) for host in $upserver do echo -n "$host: " ssh $host uptime | awk '{print $3,$4}' | sed 's/,//' done | column -t > /tmp/uptime-report.out cat /tmp/uptime-report.out | awk ' $2 >= 90' > /tmp/uptime-report-1.out cat /tmp/uptime-report-2.out | mail -s "Linux Servers Uptime Report" "[email protected]"
Set an executable permission to “system-uptime-script-1.sh” file.
$ chmod +x /opt/scripts/system-uptime-script-1.sh
Finally add a cronjob to automate this. It runs daily at 7AM.
# crontab -e 0 7 * * * /bin/bash /opt/scripts/system-uptime-script-1.sh
Note: You will receive an email alert at 7AM every day, which is for yesterday’s date details.
You will receive a report like the one below.
# cat /tmp/uptime-report-2.out 192.168.1.7: 30 days 192.168.1.9: 67 days 192.168.1.10: 130 days
…compatible with UNIX, Linux, all the way down to REDHAT 5.0
I would need a report that shows what servers are up, what are down, and what did not respond.