bash,#!/bin/bash,echo "Disk usage:",df -h,echo "Memory usage:",free -h,echo "Current logged-in users:",who,
``,,这个脚本会输出系统的磁盘使用情况、内存使用情况和当前登录的用户数。你可以根据需要添加更多的检查项。Linux 巡检脚本
在现代 IT 环境中,Linux 服务器的稳定运行是业务连续性的重要保障,为了确保服务器的健康状态,定期进行系统巡检是必不可少的,本文将介绍一个全面的 Linux 巡检脚本,该脚本涵盖了 CPU、内存、磁盘、网络、进程等多个关键指标,并附带两个常见问题的解答。
1. 脚本
这个 Linux 巡检脚本使用 Bash 编写,通过 SSH 远程连接到目标服务器执行一系列检查命令,并将结果汇总到一个日志文件中,以下是脚本的主要功能:
CPU 使用率:检查 CPU 的当前使用情况。
内存使用情况:包括总内存、已用内存和可用内存。
磁盘使用情况:检查根目录和数据目录的磁盘使用率。
网络连接:列出当前的网络连接状态。
进程状态:检查特定进程是否运行正常。
日志文件检查:查看系统日志中的错误信息。
2. 脚本代码
#!/bin/bash 定义日志文件路径 LOG_FILE="/var/log/server_check.log" > $LOG_FILE 获取当前日期和时间 current_time=$(date "+%Y-%m-%d %H:%M:%S") echo "巡检开始时间: $current_time" >> $LOG_FILE 检查 CPU 使用率 echo "CPU 使用率:" >> $LOG_FILE mpstat >> $LOG_FILE 检查内存使用情况 echo "内存使用情况:" >> $LOG_FILE free -m >> $LOG_FILE 检查磁盘使用情况 echo "磁盘使用情况:" >> $LOG_FILE df -h >> $LOG_FILE 检查网络连接 echo "网络连接:" >> $LOG_FILE netstat -tuln >> $LOG_FILE 检查特定进程状态(nginx) echo "进程状态:" >> $LOG_FILE ps aux | grep nginx >> $LOG_FILE 查看系统日志中的错误信息 echo "系统日志错误信息:" >> $LOG_FILE grep "error" /var/log/syslog >> $LOG_FILE 获取当前日期和时间 current_time=$(date "+%Y-%m-%d %H:%M:%S") echo "巡检结束时间: $current_time" >> $LOG_FILE
3. 使用方法
1、将上述脚本保存为server_check.sh
。
2、赋予脚本执行权限:chmod +x server_check.sh
。
3、通过 SSH 远程连接到目标服务器,执行脚本:ssh user@server 'bash -s' < server_check.sh
。
4、脚本执行完成后,会在/var/log/server_check.log
中生成巡检报告。
4. 常见问题解答 (FAQs)
Q1: 如何修改脚本以检查不同的进程?
A1: 你可以在脚本中替换grep nginx
部分,改为你要检查的其他进程名称,如果你想检查 MySQL 服务的状态,可以将grep nginx
改为grep mysqld
。
Q2: 如果巡检过程中出现错误怎么办?
A2: 如果巡检过程中出现错误,脚本会继续执行并将错误信息记录到日志文件中,你可以查看日志文件来确定具体的错误原因,如果需要更详细的错误信息,可以在每个命令后面添加|| echo "命令失败"
,以便更好地定位问题。
5. 上文归纳
通过定期运行这个 Linux 巡检脚本,你可以及时发现并解决服务器的潜在问题,确保系统的稳定运行,希望这个脚本对你有所帮助!
以上内容就是解答有关“linux 巡检脚本”的详细内容了,我相信这篇文章可以为您解决一些疑惑,有任何问题欢迎留言反馈,谢谢阅读。