在信息化浪潮席卷全球的当下,数字化转型已成为各行各业的核心驱动力,而作为这一进程守护者的运维工作,其重要性与日俱增。面对瞬息万变的IT环境,复杂多元的系统架构,以及日益严苛的服务质量要求,高效的自动化工具与脚本已成为运维人员提升工作效率、确保系统稳定性不可或缺的“秘密武器”。有鉴于此,我倾力编撰了这份精心筛选与整理的Shell脚本合集,旨在为广大的运维同行献上一份诚意满满的“运维人福利”,助您在应对日常运维挑战时如虎添翼,从容不迫。
这份脚本合集,犹如一座蕴藏着丰富矿藏的知识宝库,凝结了我在实战运维工作中积累的点滴智慧与宝贵经验。它深度聚焦服务器监控、故障排查、数据备份与恢复、性能调优、自动化部署等运维核心领域,旨在为每一位身处其中的专业人士提供全方位的支持。无论是初涉运维领域的新人,渴望快速掌握实战技巧,还是久经沙场的资深专家,寻求优化现有流程、提升运维效能的新思路,都能在这份合集中找寻到契合自身需求的解决方案。
每一款脚本均经过真实业务场景的反复打磨与严格测试,秉持着简洁高效、易于理解和使用的理念设计。它们不仅具备高度的灵活性与适应性,能够轻松应对各种复杂运维环境下的多样化需求,而且注释详尽,逻辑清晰,旨在成为您日常工作中随时查阅、快速上手的实用指南。无论是自动化执行例行任务,迅速响应突发事件,还是深入挖掘系统瓶颈,优化资源分配,这些脚本都将化身为您的得力助手,使繁复的运维工作变得有条不紊,事半功倍。
我热忱欢迎所有运维同仁自由取阅、广泛分享这份宝贵的Shell脚本资源,将其融入个人的工作实践中,或是作为团队协作、技能培训的参考资料。它们不仅是提升个人技能、优化工作流程的有效工具,更是增进同行间技术交流、知识共享的优质载体。让我们携手共进,充分运用这份脚本合集所蕴含的技术力量,积极推动运维工作的智能化、自动化进程,共同为构建稳定、高效、可靠的信息化系统保驾护航,为企业的数字化转型之路奠定坚实基础。在这个瞬息万变的数字化时代,让我们以匠心独运的运维智慧,驾驭科技之舟,破浪前行,共创辉煌!
今天我们要分析的是:
检测网卡流量,并按规定格式记录在日志中
#!/bin/bash
while :
do
#设置语言为英文,保障输出结果是英文,否则会出现bug
LANG=en
logfile=/tmp/`date +%d`.log
#将下面执行的命令结果输出重定向到logfile日志中
exec >> $logfile
date +"%F %H:%M"
#sar命令统计的流量单位为kb/s,日志格式为bps,因此要*1000*8
sar -n DEV 1 59|grep Average|grep ens33|awk '{print
$2,"\t","input:","\t",$5*1000*8,"bps","\n",$2,"\t","output:","\t",$6*1000*8,"bps
"}'
echo "####################"
#因为执行sar命令需要59秒,因此不需要sleep
done
脚本结构与变量定义
Bash
1#!/bin/bash 2while : 3do 4LANG=en 5logfile=/tmp/`date +%d`.log 6exec >> $logfile 7... 8done
#!/bin/bash:这是“shebang”行,指定使用bash shell执行此脚本。while ::无限循环,使得脚本持续运行。LANG=en:设置环境变量LANG为英文,确保sar命令输出结果为英文,避免因语言差异导致的解析问题。logfile=/tmp/date +%d.log:定义变量logfile,表示日志文件路径,其中%d代表当前日期(日),即日志文件名形如日.log,存储于/tmp目录。
重定向输出到日志文件
Bash
1exec >> $logfile
- 使用
exec命令将脚本后续所有标准输出(stdout)重定向到日志文件$logfile中。
输出当前时间
Bash
1date +"%F %H:%M"
- 使用
date命令以指定格式%F %H:%M(即年-月-日 时:分)输出当前时间,并写入日志文件。
检测并记录网卡流量
Bash
1sar -n DEV 1 59|grep Average|grep ens33|awk '{print $2,"\t","input:","\t",$5*1000*8,"bps","\n",$2,"\t","output:","\t",$6*1000*8,"bps"}'
- 使用
sar -n DEV 1 59命令统计网络设备(DEV)的网络流量,每1秒采样一次,共采样59次(约1分钟)。
ens33为要监控的网卡名,可根据实际情况替换。
- 使用
grep Average过滤出包含“Average”(平均值)的行。 - 使用
grep ens33过滤出与指定网卡相关的行。 - 使用
awk命令按指定格式输出结果:
$2:时间戳(采样时刻)。$5:输入流量(单位kb/s)。$6:输出流量(单位kb/s)。- 将输入输出流量乘以1000*8(转换为bits/s,即bps)。
输出分隔符
Bash
1echo "####################"
- 输出一个由“#”组成的分隔符,用于区分相邻两次采样的流量记录。
如何使用
- 修改网卡名:如果需要监控不同网卡的流量,修改
ens33为实际需要监控的网卡名。 - 赋予脚本执行权限:
- Bash
1chmod +x net_traffic_monitor.sh
- 运行脚本:
- Bash
1./net_traffic_monitor.sh
脚本将持续检测指定网卡(ens33)的输入输出流量,每分钟记录一次流量数据到日志文件中,格式为:时间戳 输入: 输入bps 输出: 输出bps。日志文件位于/tmp目录,文件名包含执行当天的日期,便于按日期查阅。注意,由于脚本持续运行,可能会占用一定的系统资源。如需停止脚本,可使用Ctrl+C中断或通过任务管理器等方式结束进程。
如果想上手操作练代码的同学们可以通过阿里云ecs服务器免费试用参与!
入口:新老同学免费试用