0.实现效果
每隔1分钟查询系统参数如内存信息,磁盘信息等,并将其存在.log文件中。
1.脚本文件
#!/bin/bash
#获取系统当前时间
time=$(date "+%Y-%m-%d %H:%M:%S")
echo "time:$time"
#ip的获取
ip=`ifconfig| grep -A 1 'ens33'|grep 'inet'|awk -F ':' '{print $2}'|awk '{print $1}'`
echo "ip:$ip"
#获取系统cpu使用率
sys_cpu=`top -bn 1 |grep Cpu | cut -d "," -f 1 | cut -d ":" -f 2 | awk '{print $1}'`
echo "sys_cpu:$sys_cpu"
#获取用户cpu使用率
user_cpu=`top -bn 1 |grep Cpu | cut -d "," -f 2 | awk '{print $1}'`
echo "user_cpu:$user_cpu"
#获取磁盘使用率
disk_usage=`df -lh |grep /dev/sda1 |awk '{print $5}'| tr -cd "[0-9]"`
disk_usage=`awk 'BEGIN{printf "%.4f\n",('$disk_usage'/'100')}'`
echo "disk_usage:$disk_usage"
#获取内存使用率
mem_total=`cat /proc/meminfo | grep MemTotal | awk '{print $2}' | tr -cd "[0-9]"`
mem_used=`cat /proc/meminfo | grep MemFree | awk '{print $2}' | tr -cd "[0-9]"`
mem_usage=`awk 'BEGIN{printf "%.4f\n",('$mem_used'/'$mem_total')}'`
echo "mem_usage:$mem_usage"
2.python文件
#用来调用获取系统信息的脚本
import subprocess
import time
while True:
result=subprocess.getoutput('sh /home/lim/sysinfo.sh')
with open('/var/log/elasticsearch/sysinfo.log',"a") as f:
f.write(result)
time.sleep(60)
3.程序初始化脚本
#!/bin/bash
#后台运行python程序,并将日志存在py_out.log
sudo nohup python3 -u ./sysinfo.py >py_out.log 2>&1 &
#如果出现如下错误,现新建一个py_out.log文件,并chmod 777 py_out.log