当前位置: 首页 > article >正文

并发解析hea,转为pdf格式

由于每次解析一个heap需要时间有点久,就写了一个自动解析程pdf的一个脚本。
down_lib.sh是需要自己写的哦,主要是用于下载自己所需程序的库,用于解析heap。

#!/bin/bash# 优化版通用解析脚本(并发加速):批量生成 heap profile 的 PDF 报告
# down_lib.sh, heapjx.sh 放到同一目录下。
# 用法示例: ./heapjx.sh /app/heap
START_TIME=$(date +%Y-%m-%d_%H:%M:%S)
echo "开始生成 heap profile PDF 报告... 时间戳:${START_TIME}"set -euo pipefail# 自动查找 pprof_x86 路径
PPROF="$(find ~/ -name pprof_x86 2>/dev/null | head -n1)"
if [[ -z "${PPROF}" ]]; thenecho "未找到 pprof_x86 工具,请检查环境!"exit 1
fiEXEC="${EXEC:-./ndm_locmap_lib/ndm_locmap}"
HEAP_DIR="${HEAP_DIR:-./heap}"
PDF_DIR="${PDF_DIR:-./pdf}"
NDM_LOCMAP_DIR="${NDM_LOCMAP_DIR:-./ndm_locmap_lib}"
LIB_PREFIX="${LIB_PREFIX:-./ndm_locmap_lib}"
OPTS="--pdf --show_bytes --lib_prefix=${LIB_PREFIX}"
USERNAME="${USERNAME:-root}"
HOST="${HOST:-192.168.2.62}"
YCHEAP_DIR="${YCHEAP_DIR:-/app/heap/heap/}"# 自动创建必要目录
mkdir -p "${PDF_DIR}" "${NDM_LOCMAP_DIR}"# 拉取heap文件目录
# 如果当前目录下没有 heap 目录,才拉取
echo "62板子上的heap目录: $1"
if [[ ! -d ./heap ]]; thenecho "未检测到 heap 目录,执行拉取..."scp -r "${USERNAME}@${HOST}:$1" .
elseecho "heap 目录已存在,跳过拉取"
fi# 判断 ndm_locmap_lib 目录下是否有文件,无文件才拉库
if find ./ndm_locmap_lib -maxdepth 1 -type f | grep -q .; thenecho "ndm_locmap_lib 目录下已有文件,跳过拉取依赖库步骤"
elseif [[ -x ./down_lib.sh ]]; thenecho "拉取依赖库..."bash ./down_lib.sh ndm_locmap root 192.168.2.62 ./ndm_locmap_lib || \echo "警告: down_lib.sh 执行失败,跳过拉取依赖库步骤"elseecho "警告: down_lib.sh 未找到或不可执行,跳过拉取依赖库步骤"fi
fi# 处理 heap 文件
shopt -s nullglob
heap_files=("${HEAP_DIR}"/ndm_locmap_*.heap)
if [[ ${#heap_files[@]} -eq 0 ]]; thenecho "未在 ${HEAP_DIR} 目录下找到 ndm_locmap_*.heap 文件"exit 1
fi# 获取CPU核心数(并发数),允许通过环境变量指定
CPU_CORES="${CPU_CORES:-$(nproc)}"echo "开始并发生成 PDF,每次最多并发 ${CPU_CORES} 个任务..."export PPROF EXEC OPTS PDF_DIRgen_pdf() {heapfile="$1"fname=$(basename "$heapfile")base="${fname%.heap}" # 去掉结尾的 .heapoutpdf="${PDF_DIR}/${base}.heap.pdf"echo "生成 ${outpdf} ...""${PPROF}" "${EXEC}" "$heapfile" ${OPTS} > "${outpdf}"if [[ $? -eq 0 ]]; thenecho "✔ ${outpdf} 生成成功"elseecho "✗ ${outpdf} 生成失败"fi
}export -f gen_pdf# GNU parallel优先,否则用xargs(大多数Linux系统已自带)
if command -v parallel &> /dev/null; thenprintf "%s\n" "${heap_files[@]}" | parallel -j "${CPU_CORES}" gen_pdf {}
elseprintf "%s\n" "${heap_files[@]}" | xargs -n1 -P "${CPU_CORES}" -I{} bash -c 'gen_pdf "$@"' _ {}
fiENDTIME=$(date +%Y-%m-%d_%H:%M:%S)
echo "全部并发生成完成!时间戳:${ENDTIME}"
http://www.lryc.cn/news/2395990.html

相关文章:

  • 【C语言】详解 指针
  • RabbitMQ仲裁队列高可用架构解析
  • 刚出炉热乎的。UniApp X 封装 uni.request
  • Apache Kafka 实现原理深度解析:生产、存储与消费全流程
  • Python 训练营打卡 Day 41
  • leetcode付费题 353. 贪吃蛇游戏解题思路
  • CCPC dongbei 2025 I
  • 系统性学习C语言-第十三讲-深入理解指针(3)
  • 代理模式核心概念
  • uni-app学习笔记十五-vue3页面生命周期(二)
  • 贪心算法实战篇2
  • Java 大视界 -- Java 大数据机器学习模型在元宇宙虚拟场景智能交互中的关键技术(239)
  • Flask中关于app.url_map属性的用法
  • 高速串行接口
  • 学习STC51单片机23(芯片为STC89C52RCRC)
  • 一个完整的日志收集方案:Elasticsearch + Logstash + Kibana+Filebeat (一)
  • 网络系统中安全漏洞扫描为何重要?扫描啥?咋扫描?
  • HiveSQL语法全解析与实战指南
  • 【conda报错】InvalidArchiveError
  • Socket 编程 TCP
  • Redis-6.2.9 Sentinel 哨兵配置
  • 基于TMC5160堵转检测技术的夹紧力控制系统设计与实现
  • 从零开始搞个简易分布式部署环境
  • XCTF-web-fileclude
  • OpenShift AI - 启用过时版本的 Notebook 镜像
  • Redis 缓存穿透、缓存击穿、缓存雪崩详解与解决方案
  • sass高阶应用
  • docker docker-ce docker.io
  • DQN和DDQN(进阶版)
  • 【组件】翻牌器效果