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

shell脚本--查看应用的cpu 和 内存使用率 并把最新告警内容显示出来

#/bin/bash

#awk NR==2'{print $4}':awk 处理前一步结果,NR==2 表示取第 2 行,print $4 提取该行第 4 列内容(一般是进程 PID),最终把 PID 赋值给变量 ics_pid

ics_pid=ps -efl |grep app |grep -v grep |awk NR==2'{print $4}'

#| awk '{print $9}':提取每行第 9 列(top 中第 9 列默认是 CPU 使用率)。awk NR==1'{print $1}':在 CPU 使用率结果里,取第 1 行数据,赋值给 cpu_usage(理论上多次采集结果一致,取首行简化)。

cpu_usage=top -n 3 |grep $ics_pid |awk '{print $9}'|awk NR==1'{print $1}'

mem_usage=top -n 3 |grep $ics_pid |awk '{print $10}'|awk NR==1'{print $1}'

#date +"%Y-%m-%d %H:%M:%S":调用系统 date 命令,按年-月-日 时:分:秒格式输出当前时间。

date1=date +"%Y-%m-%d %H:%M:%S"

date=date +"%Y%m%d"

#重定向cpu 使用率到固定文件中

echo "$date app cpu_usage $cpu_usage" > /xxx/$date1.log

#追加内存使用到文件中

echo "$date app mem usage $mem_usage" >> /xxx/$date1.log

#查看是否有告警日志

num=ls /xxx/log |grep vquar.log|wc -l

#大于等于

if [ $num -ge 1 ];then

#有告警日志

echo "##### has gaojing file######" >> /xxx/$date1.log

#把告警日志最后100行追加到固定文件中

tail -100 /xxx/vquar.log >> /xxx/$date1.log

fi

cat /xxx/$date1.log

http://www.xdnf.cn/news/13175.html

相关文章:

  • Huggingface-CLI的使用
  • AIStarter 4.0 苹果版体验评测|轻松部署 ComfyUI 与 DeepSeek 的 AI 工具箱
  • 二刷苍穹外卖 day01
  • 为MySQL社区版实现审计功能:从插件配置到日志监控全解析
  • python 本地运行Qwen3-Embedding-0.6B 模型提供API接口
  • 【QT】通讯类HttpAPI:获取MAC、主机IP、端口IP有效性判断
  • CTFSHOW pwn143 WP
  • linux 更新ollama服务
  • 亚马逊云科技 Amazon Pinpoint 解决方案:构建智能全渠道互动平台,重塑用户增长体验
  • 数据库管理与高可用-PostgreSQL初体验
  • [特殊字符] 智能合约中的数据是如何在区块链中保持一致的?
  • 安全生产管理是什么?安全生产管理系统都有哪些核心功能?
  • Android 应用开发概述与环境搭建指南
  • DBSyncer:一款开源的数据同步工具
  • Windows上SSH连接Ubuntu失败
  • 记录下three.js学习过程中不理解问题③
  • pnpm安装和使用
  • Hyperlane 框架详解与使用指南
  • 如何使用java把文件转成十六进制字符串
  • DevSecOps实践:CI/CD流水线集成SAST工具详解
  • 8.1.排序的基本概念
  • 麒麟系统集成开发环境Kylin-IDE初体验,菜鸟小白入门教程
  • 基于vue+js的微信小程序高血压健康管理系统的设计与实现(源码+论文+调试+安装+售后)
  • 在微信小程序中使用骨架屏
  • 微信小程序之bind和catch
  • USB over Network技术重塑中国电气装备集团U盾智能化管控
  • Vue大文件上传:让你的文件秒传、断点续传、分片上传---需要后端支持--案例后端使用node
  • ArcGIS Pro 3.4 二次开发 - 流图层
  • 如何对目标检测算法RT-DETR进行创新和改进:突破瓶颈,提升性能!
  • docker compose v2版本创建和运行容器