扫码订阅《 》或入驻星球,即可阅读文章!

GOLANG ROADMAP

阅读模式

  • 沉浸
  • 自动
  • 日常
首页
Go学习
  • Go学院

    • Go小课
    • Go视界
    • Go小考
    • Go实战
  • Go资源

    • 优质课程
    • 在线宝典
    • 资源下载
    • 帮找资源
训练营 🔥
  • Go体系课&实战训练营
  • 升值加薪陪跑训练营
Go求职
  • 求职刷题

    • 企业题库
    • 面试宝典
    • 求职面经
  • 求职服务

    • 内推互助
    • 求职助力
    • 内推公司
Go友会
  • 城市
  • 校园
推广返佣
  • 返佣排行
  • 返佣规则
  • 推广学院
实验区
  • Go周边
  • Go宝典

    • 推荐图书
    • 精品博文
  • Go开源

    • Go仓库
    • Go月刊
更多
  • 用户中心

    • 我的信息
    • 我的返佣
    • 我的消息
  • 玩转星球

    • 星球介绍
    • 星主权益
    • 吐槽专区
    • 成长记录
  • 合作交流

    • 商务合作
    • 讲师招募
    • 生态伙伴
author-avatar

GOLANG ROADMAP


首页
Go学习
  • Go学院

    • Go小课
    • Go视界
    • Go小考
    • Go实战
  • Go资源

    • 优质课程
    • 在线宝典
    • 资源下载
    • 帮找资源
训练营 🔥
  • Go体系课&实战训练营
  • 升值加薪陪跑训练营
Go求职
  • 求职刷题

    • 企业题库
    • 面试宝典
    • 求职面经
  • 求职服务

    • 内推互助
    • 求职助力
    • 内推公司
Go友会
  • 城市
  • 校园
推广返佣
  • 返佣排行
  • 返佣规则
  • 推广学院
实验区
  • Go周边
  • Go宝典

    • 推荐图书
    • 精品博文
  • Go开源

    • Go仓库
    • Go月刊
更多
  • 用户中心

    • 我的信息
    • 我的返佣
    • 我的消息
  • 玩转星球

    • 星球介绍
    • 星主权益
    • 吐槽专区
    • 成长记录
  • 合作交流

    • 商务合作
    • 讲师招募
    • 生态伙伴
  • Linux运维系列

    • 《Linux》
  • Linux基础

    • 1.学会使用命令帮助
    • 1.文件及目录管理
    • 3.文本处理
    • 4.磁盘管理
    • 5.进程管理工具
    • 6.性能监控
    • 7.网络工具
    • 8.用户管理工具
    • 9.系统管理及IPC资源管理
  • Linux工具进阶

    • 1.程序构建
    • 2.程序调试
    • 3.性能优化
  • 工具参考

    • 1.gdb 调试利器
    • 2.ldd 查看程序依赖库
    • 3.lsof 一切皆文件
    • 4.ps 进程查看器
    • 5.pstack 跟踪进程栈
    • 6.strace 跟踪进程中的系统调用
    • 7.ipcs 查询进程间通信状态
    • 8.top linux下的任务管理器
    • 9.free 查询可用内存
    • 10.vmstat 监视内存使用情况
    • 11.iostat 监视I/O子系统
    • 12.sar 找出系统瓶颈的利器
    • 13.readelf elf文件格式分析
    • 14.objdump 二进制文件分析
    • 15.nm 目标文件格式分析
    • 16.size 查看程序内存映像大小
    • 17.wget 文件下载
    • 18.scp 跨机远程拷贝
    • 19.crontab 定时任务

扫码订阅《 》或入驻星球,即可阅读文章!

6.性能监控


GOLANG ROADMAP

在使用操作系统的过程中,我们经常需要查看当前的性能如何,需要了解CPU、内存和硬盘的使用情况;本节介绍的这几个工具能满足日常工作要求;

# 6.1. 监控CPU

查看CPU使用率

- sar -u
 
eg:
- sar -u 1 2
[/home/weber#]sar -u 1 2
Linux 2.6.35-22-generic-pae (MyVPS)     06/28/2014      _i686_  (1 CPU)
 
09:03:59 AM     CPU     %user     %nice   %system   %iowait    %steal     %idle
09:04:00 AM     all      0.00      0.00      0.50      0.00      0.00     99.50
09:04:01 AM     all      0.00      0.00      0.00      0.00      0.00    100.00
1
2
3
4
5
6
7
8
9
10

后面的两个参数表示监控的频率,比如例子中的1和2,表示每秒采样一次,总共采样2次;

查看CPU平均负载

- sar -q 1 2
1

sar指定-q后,就能查看运行队列中的进程数、系统上的进程大小、平均负载等;

# 6.2. 查询内存

查看内存使用状况sar指定-r之后,可查看内存使用状况;

- sar -r 1 2
09:08:48 AM kbmemfree kbmemused  %memused kbbuffers  kbcached  kbcommit   %commit  kbactive   kbinact
09:08:49 AM     17888    359784     95.26     37796     73272    507004     65.42    137400    150764
09:08:50 AM     17888    359784     95.26     37796     73272    507004     65.42    137400    150764
Average:        17888    359784     95.26     37796     73272    507004     65.42    137400    150764
1
2
3
4
5

查看内存使用量

- free -m
1

# 6.3. 查询页面交换

查看页面交换发生状况页面发生交换时,服务器的吞吐量会大幅下降;服务器状况不良时,如果怀疑因为内存不足而导致了页面交换的发生,可以使用sar -W这个命令来确认是否发生了大量的交换;

- sar -W 1 3
1

# 6.4. 查询硬盘使用

查看磁盘空间利用情况

- df -h
1

查询当前目录下空间使用情况

du -sh  -h是人性化显示 s是递归整个目录的大小
1

查看该目录下所有文件夹的排序后的大小

for i in `ls`; do du -sh - i; done | sort
或者
du -sh `ls`
1
2
3

# 6.5. 综合应用

当系统中sar不可用时,可以使用以下工具替代:linux下有 vmstat、Unix系统有prstat

eg:查看cpu、内存、使用情况:vmstat n m (n 为监控频率、m为监控次数)

[/home/weber#]vmstat 1 3
procs -----------memory---------- ---swap-- -----io---- -system-- ----cpu----
r  b   swpd   free   buff  cache   si   so    bi    bo   in   cs us sy id wa
0  0  86560  42300   9752  63556    0    1     1     1    0    0  0  0 99  0
1  0  86560  39936   9764  63544    0    0     0    52   66   95  5  0 95  0
0  0  86560  42168   9772  63556    0    0     0    20  127  231 13  2 84  0
1
2
3
4
5
6

使用watch 工具监控变化当需要持续的监控应用的某个数据变化时,watch工具能满足要求;执行watch命令后,会进入到一个界面,输出当前被监控的数据,一旦数据变化,便会高亮显示变化情况;

eg:操作redis时,监控内存变化:

- watch -d -n 1 './redis-cli info | grep memory'
(以下为watch工具中的界面内容,一旦内存变化,即实时高亮显示变化)
Every 1.0s: ./redis-cli info | grep memory                                                                  Mon Apr 28 16:10:36 2014
 
used_memory:45157376
used_memory_human:43.07M
used_memory_rss:47628288
used_memory_peak:49686080
used_memory_peak_human:47.38M
1
2
3
4
5
6
7
8
9

# 6.6. 总结

top / sar / free / watch

# 6.7. 附录

关于sar的使用详解参考:sar 找出系统瓶颈的利器

  • 6.1. 监控CPU
  • 6.2. 查询内存
  • 6.3. 查询页面交换
  • 6.4. 查询硬盘使用
  • 6.5. 综合应用
  • 6.6. 总结
  • 6.7. 附录