在信息化浪潮席卷全球的当下,数字化转型已成为各行各业的核心驱动力,而作为这一进程守护者的运维工作,其重要性与日俱增。面对瞬息万变的IT环境,复杂多元的系统架构,以及日益严苛的服务质量要求,高效的自动化工具与脚本已成为运维人员提升工作效率、确保系统稳定性不可或缺的“秘密武器”。有鉴于此,我倾力编撰了这份精心筛选与整理的Shell脚本合集,旨在为广大的运维同行献上一份诚意满满的“运维人福利”,助您在应对日常运维挑战时如虎添翼,从容不迫。
这份脚本合集,犹如一座蕴藏着丰富矿藏的知识宝库,凝结了我在实战运维工作中积累的点滴智慧与宝贵经验。它深度聚焦服务器监控、故障排查、数据备份与恢复、性能调优、自动化部署等运维核心领域,旨在为每一位身处其中的专业人士提供全方位的支持。无论是初涉运维领域的新人,渴望快速掌握实战技巧,还是久经沙场的资深专家,寻求优化现有流程、提升运维效能的新思路,都能在这份合集中找寻到契合自身需求的解决方案。
每一款脚本均经过真实业务场景的反复打磨与严格测试,秉持着简洁高效、易于理解和使用的理念设计。它们不仅具备高度的灵活性与适应性,能够轻松应对各种复杂运维环境下的多样化需求,而且注释详尽,逻辑清晰,旨在成为您日常工作中随时查阅、快速上手的实用指南。无论是自动化执行例行任务,迅速响应突发事件,还是深入挖掘系统瓶颈,优化资源分配,这些脚本都将化身为您的得力助手,使繁复的运维工作变得有条不紊,事半功倍。
我热忱欢迎所有运维同仁自由取阅、广泛分享这份宝贵的Shell脚本资源,将其融入个人的工作实践中,或是作为团队协作、技能培训的参考资料。它们不仅是提升个人技能、优化工作流程的有效工具,更是增进同行间技术交流、知识共享的优质载体。让我们携手共进,充分运用这份脚本合集所蕴含的技术力量,积极推动运维工作的智能化、自动化进程,共同为构建稳定、高效、可靠的信息化系统保驾护航,为企业的数字化转型之路奠定坚实基础。在这个瞬息万变的数字化时代,让我们以匠心独运的运维智慧,驾驭科技之舟,破浪前行,共创辉煌!
今天我们要分析的是:
判断目录 /tmp/jstack 是否存在,不存在则新建一个目录,若存在则删除目录下所有内容。每隔 1 小时打印 inceptor server 的 jstack 信息,并以 jstack_${当前时间} 命名文件,每当目录下超过10 个文件后,删除最旧的文件。
#!/bin/bash
DIRPATH='/tmp/jstack'
CURRENT_TIME=$(date +'%F'-'%H:%M:%S')
if [ ! -d "$DIRPATH" ];then
mkdir "$DIRPATH"
else
rm -rf "$DIRPATH"/*
fi
cd "$DIRPATH"
while true
do
sleep 3600
# 这里需要将inceptor改后自己的java进程名称
pid=$(ps -ef | grep 'inceptor' | grep -v grep | awk '{print $2}')
jstack $pid >> "jstack_${CURRENT_TIME}"
dir_count=$(ls | wc -l)
if [ "$dir_count" -gt 10 ];then
rm -f $(ls -tr | head -1)
fi
done
脚本结构与变量定义
Bash
1#!/bin/bash 2DIRPATH='/tmp/jstack' 3CURRENT_TIME=$(date +'%F-%H:%M:%S')
#!/bin/bash
:这是“shebang”行,指定使用bash shell执行此脚本。DIRPATH='/tmp/jstack'
:定义变量DIRPATH
,表示要管理的目录路径。CURRENT_TIME=$(date +'%F-%H:%M:%S')
:使用date
命令获取当前日期和时间(格式为年-月-日-时:分:秒
),将结果存储在CURRENT_TIME
变量中。
判断与创建/清理目录
Bash
1if [ ! -d "$DIRPATH" ];then 2mkdir "$DIRPATH" 3else 4rm -rf "$DIRPATH"/* 5fi
- 判断
DIRPATH
所指的目录是否存在:
- 如果不存在,使用
mkdir "$DIRPATH"
创建该目录。 - 如果存在,使用
rm -rf "$DIRPATH"/*
删除目录下所有内容。
循环执行任务
Bash
1cd "$DIRPATH" 2while true 3do 4sleep 3600 5# 这里需要将inceptor改后自己的java进程名称 6pid=$(ps -ef | grep 'inceptor' | grep -v grep | awk '{print $2}') 7jstack $pid >> "jstack_${CURRENT_TIME}" 8dir_count=$(ls | wc -l) 9if [ "$dir_count" -gt 10 ];then 10rm -rf $(ls -tr | head -1) 11fi 12done
- 使用
cd "$DIRPATH"
切换到目标目录。 - 开始无限循环(
while true
):
- 使用
sleep 3600
暂停一小时。 - 获取指定Java进程(此处为inceptor server,可根据实际情况替换)的PID:
ps -ef
列出所有进程信息。grep 'inceptor'
筛选出包含关键词"inceptor"的行。grep -v grep
排除掉包含"grep inceptor"本身的行(避免脚本自身的grep命令被匹配)。awk '{print $2}'
提取出第二列(PID)。- 结果存储在变量
pid
中。
- 使用
jstack $pid
获取指定PID的Java进程堆栈信息,并追加到文件jstack_${CURRENT_TIME}
中。 - 使用
dir_count=$(ls | wc -l)
统计当前目录下文件数量,存储在变量dir_count
中。 - 判断文件数量是否超过10个:
- 如果超过10个,使用
rm -rf $(ls -tr | head -1)
删除最旧的文件(ls -tr
按时间顺序排序并输出,head -1
选取第一个,即最旧文件)。
如何使用
- 确保目标进程名正确:请将
ps -ef | grep 'inceptor'
中的'inceptor'替换为您实际要监控的Java进程名。 - 赋予脚本执行权限:
- Bash
1chmod +x your_script.sh
- 运行脚本:
- Bash
1./your_script.sh
脚本将按计划管理/tmp/jstack
目录,定时清理内容、捕获指定Java进程的jstack信息,并根据需要删除最旧的文件。通过运行此脚本,您可以定期收集目标Java进程的堆栈信息,便于分析系统性能或排查问题。
如果想上手操作练代码的同学们可以通过阿里云ecs服务器免费试用参与!
入口:新老同学免费试用