【打dunp和堆栈的脚本】

【打dunp和堆栈的脚本】

背景:
最近在要写一个打dunp和堆栈的脚本,方便后期操作的
(环境:使用了的容器的,在宿主机上跑脚本)

脚本:

#!/bin/bash

# 定义常量
TARGET_PATH="xxxxx"
JDK_DIR="/app/jdk1.8.0_181/bin/" 
STACK_FILE_PREFIX="stack"
DUMP_FILE_PREFIX="heap_dump"
OPERATION=$1

# 设置导出次数
count=5
# 设置导出间隔(秒)
interval=5

#检查目录是否存在这里要写到容器的文件中
#if [ ! -d "$TARGET_PATH" ]; then
#    echo "目录不存在,开始创建..."
#    # 创建级联目录
#    mkdir -p "$TARGET_PATH"
#    # 设置权限为 755
#    find "$TARGET_PATH" -type d -exec chmod 755 {} +
#else
#    echo "目录已存在,无需创建。"
#fi

#获取本地ip


#容器操作

# 1. 获取容器ID并进入容器

CONTAINER_ID=$(docker ps  | grep tomcat | grep -v grep | awk '{print $1}')

if [ -z "$CONTAINER_ID" ]; then
    echo "$(date +%Y%m%d%H%M%S)未找到容器ID,请确认容器是否在运行"  >> "$TARGET_PATH/$log_file"
	
    exit 1
fi

echo "$(date +%Y%m%d%H%M%S)进入容器 $CONTAINER_ID ..."  >> "$TARGET_PATH/$log_file"
docker exec -it "$CONTAINER_ID" bash 

#2. 查询进程PID
cd /app/jdk1.8.0_181/bin/ || { echo "$(date +%Y%m%d%H%M%S)目录不存在" >> "$TARGET_PATH/$log_file"; exit 1; }

#进行ps查询,提取PID
PID=$(ps -ef | grep '[t]omcat.*startup.Bootstrap start' | awk '{print $2}')
if [ -z "$PID" ]; then
    echo "$(date +%Y%m%d%H%M%S)未找到相应的tomcat进程" >> "$TARGET_PATH/$log_file"
    exit 1
fi

echo "找到的PID: $PID"


# 执行操作
case $OPERATION in
    stack)
	# 循环导出堆栈
			for (( i=1; i<=count; i++ ))
			do
			echo "$(date +%Y%m%d%H%M%S)导出堆栈到 $TARGET_PATH/${STACK_FILE_PREFIX}_$(APP_IP)_${i}.txt"  >> "$TARGET_PATH/$log_file"
					docker exec -it $CONTAINER_ID bash -c "cd $JDK_DIR && ./jstack -l $PID > $TARGET_PATH/${STACK_FILE_PREFIX}_$(APP_IP)_${i}.txt"
					;;
			# 等待指定时间
			sleep $interval
			done
        
    dump)
        DUMP_FILE="${DUMP_FILE_PREFIX}_$(APP_IP).hprof"
        echo "$(date +%Y%m%d%H%M%S)导出 Dump 到 $TARGET_PATH/$DUMP_FILE"  >> "$TARGET_PATH/$log_file"
        docker exec $CONTAINER_ID bash -c "cd $JDK_DIR && ./jmap -dump:format=b,live,file=$TARGET_PATH/$DUMP_FILE $PID"
        if [ $? -ne 0 ]; then
            echo "$(date +%Y%m%d%H%M%S)jmap 导出 Dump 失败,尝试使用 jcmd..."  >> "$TARGET_PATH/$log_file"
            docker exec $CONTAINER_ID bash -c "cd $JDK_DIR && ./jcmd $PID GC.heap_dump $TARGET_PATH/$DUMP_FILE"
        fi
        ;;
    *)
        echo "$(date +%Y%m%d%H%M%S)无效的操作: $OPERATION"  >> "$TARGET_PATH/$log_file"
        echo "$(date +%Y%m%d%H%M%S)操作: stack 或 dump"  >> "$TARGET_PATH/$log_file"
        exit 1
        ;;
esac

echo "$(date +%Y%m%d%H%M%S)操作完成。" >> "$TARGET_PATH/$log_file"

问题:
本人在我们的生产环境执行的时候,其中在$PID传入参数的时候,并没有实现的真正的入参,用了很多方法,都没有传入成功

将参数写死,是没有问题的
这里还需要后续优化

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在使用 SQlyog 导出数据库时,有时会遇到“64位无法保存 SQlyog dump 文件”的问题。这个问题可能出现在使用较旧的版本,并且可能与操作系统的 64 位架构有关。出现这个问题时,可能会收到一个错误消息,提示无法保存 SQLyog Dump 文件。 这个问题可能有多种解决方案,下面介绍一些常见的方法。 首先,建议检查一下电脑的系统环境是否正常。确保已经在操作系统中安装了正确的数据库软件,并且已经启动了数据库服务。如果电脑的操作系统是 64 位,那么确保 SQLyog 和数据库软件都是 64 位版本。 其次,可以尝试升级 SQlyog 的版本。有些版本的 SQlyog 可能存在一些兼容性问题,而新版的软件通常已经解决了这些问题。如果已经安装的是较旧的版本,可以尝试升级到最新版本并重试导出数据库。 另外,也可以尝试将导出文件保存到其他地方,比如保存到桌面或其他硬盘分区。有的时候,某些目录可能设置了权限限制,导致无法保存文件,所以更改保存位置可能会解决问题。 最后,如果上述方法都无法解决问题,可以考虑使用其他 SQL 工具来导出数据库。有很多免费的 SQL 工具可供选择,例如 Navicat、HeidiSQL 等,也可以考虑使用命令行工具直接导出 SQL 文件。 总之,出现“64位无法保存 SQlyog dump 文件”的问题可能有多种原因,需要根据具体情况灵活处理。找到合适的解决方案,有助于保障数据的安全。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值