linux统计字符串出现次数 linux查询关键字出现的个数了解( 二 )

  • 将第二步结果通过命令awk 将字符串分割,$n(0~N) 对应相应的参数,如下图多少$2对应地址:192.168.0.125,**\'{print 2}’**打印出2的值
  • 将第三步的结果赋值给变量IP
  • echo “IP地址:”$IP打印出变量IP的值,【后面脚本中赋值和打印的语句功能相同,不再重复解释】
  • 2. 获取cpu总核数cpu_num=`grep -c \"model name\" /proc/cpuinfo`echo \"cpu总核数:\"$cpu_num
    1. 在linux的/proc目录下存放了系统运行的很多系统资源信息,其中**/proc/cpuinfo**存放了系统运行时cpu的很多重要信息 。
    2. 所有的cpu核信息由model name字符串给出,
    3. 通过命令**grep -c “model name” /proc/cpuinfo** 可以计算出文件 /proc/cpuinfo中出现字符串model name出现的次数,就可以得到cpu总核数 。-c 表示统计字符串出现次数 。
    如下所示:
    linux统计字符串出现次数 linux查询关键字出现的个数了解

    文章插图
    3. 获取CPU利用率top命令经常用来监控linux的系统状况,是常用的性能分析工具,能够实时显示系统中各个进程的资源占用情况 。
    # 获取用户空间占用CPU百分比cpu_user=`top -b -n 1 | grep Cpu | awk \'{print $2}\' | cut -f 1 -d \"%\"`echo \"用户空间占用CPU百分比:\"$cpu_user # 获取内核空间占用CPU百分比cpu_system=`top -b -n 1 | grep Cpu | awk \'{print $4}\' | cut -f 1 -d \"%\"`echo \"内核空间占用CPU百分比:\"$cpu_system # 获取空闲CPU百分比cpu_idle=`top -b -n 1 | grep Cpu | awk \'{print $8}\' | cut -f 1 -d \"%\"`echo \"空闲CPU百分比:\"$cpu_idle # 获取等待输入输出占CPU百分比cpu_iowait=`top -b -n 1 | grep Cpu | awk \'{print $10}\' | cut -f 1 -d \"%\"`echo \"等待输入输出占CPU百分比:\"$cpu_iowait
    linux统计字符串出现次数 linux查询关键字出现的个数了解

    文章插图
    top
    1. top -b -n 1显示系统的信息并以格式化打印,结果只刷新一次
    n 设置退出前屏幕刷新的次数b 将top输出编排成适合输出到文件的格式,可以使用这个选项创建进程日志
    1. grep Cpu提取出字符串Cpu所在的行
    2. awk ‘{print $2}’将第二步得到的字符串分割,并调用方法print 打印出**$2**对应的第二个字符串,0.5%us
    3. cut -f 1 -d “%” 表示以%为分隔符,将第三步的结果分隔开,并显示分割后的记过的第一个字符串即0.5
    -d\"%\" 是以%作为分隔符,-f 1显示以:分割每一行的第一段内容
    1. 其他脚本以此类推
    其他Cpu利用率参数含义如下:
    #us 用户空间占用CPU百分比#sy 内核空间占用CPU百分比#ni 用户进程空间内改变过优先级的进程占用CPU百分比#id 空闲CPU百分比#wa 等待输入输出的CPU时间百分比#hi 硬件中断#si 软件中断4.获取CPU上下文切换和中断次数# 获取CPU中断次数cpu_interrupt=`vmstat -n 1 1 | sed -n 3p | awk \'{print $11}\'`echo \"CPU中断次数:\"$cpu_interrupt # 获取CPU上下文切换次数cpu_context_switch=`vmstat -n 1 1 | sed -n 3p | awk \'{print $12}\'`echo \"CPU上下文切换次数:\"$cpu_context_switch# 获取任务队列(就绪状态等待的进程数)cpu_task_length=`vmstat -n 1 1 | sed -n 3p | awk \'{print $1}\'`echo \"CPU任务队列长度:\"$cpu_task_length
    1. vmstat是Virtual Meomory Statistics(虚拟内存统计)的缩写,可对操作系统的虚拟内存、进程、CPU活动进行监控 。是对系统的整体情况进行统计,不足之处是无法对某个进程进行深入分析 。vmstat -n 1 1只显示一次各字段名称 。
    -n:只在开始时显示一次各字段名称 。
    1. sed -n 3p将第一步的结果打印出第3行
    参数说明:-n或--quiet或--silent 取消自动打印模式空间,仅显示script处理后的结果 。动作说明:p :打印,亦即将某个选择的数据印出 。通常 p 会与参数 sed -n 一起运行~
    1. **awk ‘{print $1}’`**将第2步结果得出的字符串分割,并打印第一个字符串

    linux统计字符串出现次数 linux查询关键字出现的个数了解

    文章插图
    vmstat
    5、获取CPU负载信息【linux统计字符串出现次数 linux查询关键字出现的个数了解】# 获取CPU15分钟前到现在的负载平均值cpu_load_15min=`uptime | awk \'{print $11}\' | cut -f 1 -d \',\'`echo \"CPU 15分钟前到现在的负载平均值:\"$cpu_load_15min # 获取CPU5分钟前到现在的负载平均值cpu_load_5min=`uptime | awk \'{print $10}\' | cut -f 1 -d \',\'`echo \"CPU 5分钟前到现在的负载平均值:\"$cpu_load_5min # 获取CPU1分钟前到现在的负载平均值cpu_load_1min=`uptime | awk \'{print $9}\' | cut -f 1 -d \',\'`echo \"CPU 1分钟前到现在的负载平均值:\"$cpu_load_1min