信息化浪潮席卷全球的当下,数字化转型已成为各行各业的核心驱动力,而作为这一进程守护者的运维工作,其重要性与日俱增。面对瞬息万变的IT环境,复杂多元的系统架构,以及日益严苛的服务质量要求,高效的自动化工具与脚本已成为运维人员提升工作效率、确保系统稳定性不可或缺的“秘密武器”。有鉴于此,我倾力编撰了这份精心筛选与整理的Shell脚本合集,旨在为广大的运维同行献上一份诚意满满的“运维人福利”,助您在应对日常运维挑战时如虎添翼,从容不迫。
这份脚本合集,犹如一座蕴藏着丰富矿藏的知识宝库,凝结了我在实战运维工作中积累的点滴智慧与宝贵经验。它深度聚焦服务器监控、故障排查、数据备份与恢复、性能调优、自动化部署等运维核心领域,旨在为每一位身处其中的专业人士提供全方位的支持。无论是初涉运维领域的新人,渴望快速掌握实战技巧,还是久经沙场的资深专家,寻求优化现有流程、提升运维效能的新思路,都能在这份合集中找寻到契合自身需求的解决方案。
每一款脚本均经过真实业务场景的反复打磨与严格测试,秉持着简洁高效、易于理解和使用的理念设计。它们不仅具备高度的灵活性与适应性,能够轻松应对各种复杂运维环境下的多样化需求,而且注释详尽,逻辑清晰,旨在成为您日常工作中随时查阅、快速上手的实用指南。无论是自动化执行例行任务,迅速响应突发事件,还是深入挖掘系统瓶颈,优化资源分配,这些脚本都将化身为您的得力助手,使繁复的运维工作变得有条不紊,事半功倍。
我热忱欢迎所有运维同仁自由取阅、广泛分享这份宝贵的Shell脚本资源,将其融入个人的工作实践中,或是作为团队协作、技能培训的参考资料。它们不仅是提升个人技能、优化工作流程的有效工具,更是增进同行间技术交流、知识共享的优质载体。让我们携手共进,充分运用这份脚本合集所蕴含的技术力量,积极推动运维工作的智能化、自动化进程,共同为构建稳定、高效、可靠的信息化系统保驾护航,为企业的数字化转型之路奠定坚实基础。在这个瞬息万变的数字化时代,让我们以匠心独运的运维智慧,驾驭科技之舟,破浪前行,共创辉煌!
今天我们要分析的是:
轮询检测Apache状态并启用钉钉报警
#!/bin/bash
shell_user="root"
shell_domain="apache"
shell_list="/root/ip_list"
shell_row=`cat $shell_list |wc -l`
function trans_text(){
text=$1
curl 'https://oapi.dingtalk.com/robot/send?access_token=b4fcf5862088a1bc7f2bf66a'
-H'Content-Type: application/json' -d'{ #指定钉钉机器人hook地址
"msgtype": "text",
"text": {
"content": "'"$text"'"
},
}'
}
function apache_check_80(){
ip=$1
URL="http://$ip/index.html"
HTTP_CODE=`curl -o /dev/null -s -w "%{http_code}" "${URL}"`
if [ $HTTP_CODE != 200 ]
then
trans_text "
=================================================================
\n $ip Apache 服务器状态异常,网页返回码:
'"$HTTP_CODE"' 请及时处理 ! \n
================================================================= \n"
fi
}
while true
do
shell_list="/root/ip_list"
shell_row=`cat $shell_list |wc -l`
for temp in `seq 1 $shell_row`
do
Ip_Addr=`cat $shell_list |head -n $temp |tail -n 1`
apache_check_80 $Ip_Addr
done
sleep 10
done
脚本结构概览
- 变量定义
shell_user
: 脚本执行用户(此处为“root”)。shell_domain
: 被监测服务的描述(此处为“apache”)。shell_list
: 存放待检测服务器IP地址的文本文件路径(/root/ip_list
)。shell_row
: 计算shell_list
文件中的行数(即IP地址总数)。
- 辅助函数
trans_text()
: 接收报警消息文本作为参数,通过Curl向钉钉机器人发送文本消息。apache_check_80()
: 根据传入的IP地址检测Apache服务器在端口80上的状态,如有异常发送报警。
- 主循环
- 无限循环读取
shell_list
中的IP地址,逐个进行状态检测。 - 每检测完一轮,暂停10秒后继续下一轮。
功能详解
trans_text() 函数
- 发送钉钉消息
- 使用Curl向钉钉机器人提供的API(
https://oapi.dingtalk.com/robot/send?access_token=b4fcf5862088a1bc7f2bf66a
)发起POST请求。 - 请求头指定
Content-Type: application/json
。 - 请求体构造为JSON格式,包含
msgtype
(消息类型,固定为"text")和text
对象(内容为传入的报警文本)。
apache_check_80() 函数
- 获取服务器状态
- 接收IP地址作为参数。
- 使用Curl访问目标服务器的默认页面(
http://$ip/index.html
),并获取HTTP响应码(%{http_code}
)。
- 判断与报警
- 如果HTTP响应码不等于200(表示请求未成功),调用
trans_text()
函数,传入包含IP地址、服务名及响应码的报警文本。
主循环
- 逐个检测
- 初始化
shell_list
与shell_row
。 - 使用
for
循环遍历shell_list
中的每一行(即每一个IP地址)。 - 对每个IP地址调用
apache_check_80()
函数进行状态检测。
- 定时轮询
- 检测完一轮后,使用
sleep 10
让脚本暂停10秒。 - 循环回到起点,继续下一轮检测。
如何使用
- 配置钉钉机器人
- 在钉钉群聊中创建一个自定义机器人,获取其访问令牌(access_token),替换脚本中相应位置的
b4fcf5862088a1bc7f2bf66a
。
- 准备IP列表
- 在
/root/ip_list
文件中,以每行一个IP地址的形式列出待检测的Apache服务器IP。
- 权限与执行
- 确保运行此脚本的用户有权限执行Curl和访问
/root/ip_list
文件。 - 可以直接运行脚本启动监测,或将其添加至系统定时任务(如
cron
)中,使其持续运行。
通过以上步骤,该脚本将定期轮询检测列表中的Apache服务器状态。当检测到某台服务器的HTTP响应码非200时,会立即通过钉钉机器人向指定群组发送报警消息。这样可以及时发现并通知运维人员处理Apache服务器的异常状况。
如果想上手操作练代码的同学们可以通过阿里云ecs服务器免费试用参与!
入口:新老同学免费试用