linux监控平台搭建-cpu
目前服务器的主流CPU是intel或者AMD。到底主频是什么。多核、多线程、并发、并行、超频、一级缓存、二级缓存、三级缓存。i386、x86
cpu:含有算术逻辑、控制、记忆等单元
频率:就是CPU每秒钟可以进行的工作次数。3.0GHz 这个CPU在一秒内进行3.0*10(9)
外频:CPU与外部组件进行数据传输、运算是的速度。最好与内存相匹配。
总核数 = 物理CPU个数 X 每颗物理CPU的核数
总逻辑CPU数 = 物理CPU个数 X 每颗物理CPU的核数 X 超线程数
查看物理CPU个数:cat /proc/cpuinfo| grep "physical id"| sort| uniq| wc -l
查看每个物理CPU中core的个数(即核数):cat /proc/cpuinfo| grep "cpu cores"| uniq
查看逻辑CPU的个数:cat /proc/cpuinfo| grep "processor"| wc -l
查看CPU信息(型号):cat /proc/cpuinfo | grep name | cut -f2 -d: | uniq -c
查看CPU的主频:cat /proc/cpuinfo |grep MHz|uniq
1.监控相关的CPU计算方法:通过采集/proc/stat来得到,大家可以参考sar命令的统计输出来理解。
cpu.idle:CPU或CPUs空闲并且系统没有未完成的磁盘I / O请求的时间百分比。
cpu.busy:与cpu.idle相对,他的值等于100减去cpu.idle。
cpu.guest:CPU或CPUS用于运行虚拟处理器的时间百分比。
cpu.iowait:CPU或CPUS用于维护硬件中断所花费的时间百分比。
cpu.irq:CPU或CPUS用于维护硬件中断所花费的时间百分比。
cpu.softirq:CPU或CPUS用于服务软件中断所花费的时间百分比。
cpu.nice:在优先级高的用户级别执行时CPU占用率的百分比。
cpu.steal:当虚拟机管理程序为另一个虚拟处理器服务时,虚拟CPU或CPUS在非自愿等待中花费的时间百分比。
cpu.system:在系统级别(内核)上执行时CPU占用率的百分比。
cpu.user:在用户级别(应用程序)执行时CPU占用率的百分比。
cpu.cnt:cpu核数。
cpu.switches:cpu上下文切换次数,计数器类型。在stat里面是这个 ctxt 30516916343
CPU时间=user+system+nice+idle+iowait+irq+softirq
例如:查看cpu核0
%usr %nice %sys %iowait %irq %soft %steal %guest %idle
cpu0 3143580 88 2678777 3863810314 2442 0 5461 0 0
btime:这行展示从系统启动到现在为止的时间(以Epoch时间开始计算, 1970-01-01 00:00:00 +0000 (UTC)),单位为秒。
processes:(total_forks) 自系统启动以来所创建的任务的个数目。
procs_running:当前运行队列的任务的数目。
procs_blocked:当前被阻塞的任务的数目。
softirq:从系统启动开始累计到当前时刻,软中断时间(单位:jiffies)
intr:这行给出中断的信息,第一个为自系统启动以来,发生的所有的中断的次数;然后每个数对应一个特定的中断自系统启动以来所发生的次数。
2.监控相关的CPU-load计算方法:读取/proc/loadavg,都是原始值类型的:
load.1min:表示最近1分钟的平均负载(取决于机器的核数)
load.5min:表示最近5分钟的平均负(取决于机器的核数)
load.15min:表示最近15分钟的平均负载(取决于机器的核数)
常用的命令:sar、mpstat、top、iostat、vmstat、w...
mpstat [-P {cpu|ALL}] [internal [count]]
3.获取进程cmd的方式:
ps -e o user,pid,cmd | grep ssh
ps w -p $pid
4.计算进程启动的时间:
ps -p $pid -o lstart
或者脚本
#!/bin/bash
pid=$1
elt=$( ps w -p $pid o pid=,cmd=,etime= | awk ‘{print $NF}‘ )
case $( echo $elt | sed -e ‘s/:/:\n/g‘ | grep ":" -c ) in
"1")
elt=$( echo $elt | sed -e ‘s/:/ minutes ago /‘ )
;;
*)
elt=$( echo $elt | sed -e ‘s/-/ days ago /‘ -e ‘s/:/ hours ago /‘ -e ‘s/:/ minutes ago /‘ )
;;
esac
date -d "$elt seconds ago"
5.查看单个进程的状态:
cat /proc/$pid/stat