linux 系统性能评估与优化方案

本贴最后更新于 2278 天前,其中的信息可能已经事过境迁

cpu 性能评估

grep "processor" /proc/cpuinfo|wc -l《=查看 cpu 个数

vmstat 3 5

r b swpd free buff cache si so bi bo in cs us sy id wa st

0 0 0 79636 145384 182388 0 0 9 19 99 119 3 1 95 0 0

0 0 0 79184 145392 182404 0 0 0 25 139 124 6 2 92 0 0

0 0 0 79440 145392 182412 0 0 0 3 275 145 15 7 78 0 0

2 0 0 79448 145400 182408 0 0 0 17 128 126 5 2 93 0 0

0 0 0 79480 145400 182404 0 0 0 19 136 118 6 2 92 0 0

r 表示运行或等待 cpu 时间片的进程数,如果该值长时间大于 cpu 个数说明 cpu 资源不足。

bi+bo 参考值为 1000,如果大于 1000,而且 wa 值较大,说明 i/o 有问题,要想办法提高磁盘读写性能。

si 、 so 长时间不为 0 说明内存不足。

us 大于 50 说明用户进程占用过大的 cpu 资源,要优化应用程序。

us+sy 参考值 80,如果大于 80 说明 cpu 资源可能不足。

wa 参考值为 20,如果大于 20 说明磁盘读写性能有问题。

id 表示 cpu 空闲值。

sar -u 3 5 对某个系统 cpu 的统计

16:13:43 CPU %user %nice %system %iowait %steal %idle

16:13:46 all 6.08 0.00 6.08 0.00 0.00 87.84

16:13:49 all 13.27 0.00 9.18 0.00 0.00 77.55

16:13:52 all 14.97 0.00 5.78 0.00 0.00 79.25

16:13:55 all 6.73 0.00 6.06 0.00 0.00 87.21

16:13:58 all 4.05 0.00 4.73 0.34 0.00 90.88

Average: all 9.00 0.00 6.36 0.07 0.00 84.56

%nice 正常运行进程占用 cpu 时间的百分比。

%steal 表示内存紧张时 pagein 强制对不同页面做 steal。

注意的是第一行的统计信息包含使用 sar 命令消耗的统计。

sar -P 0 3 5 针对某个 cpu 进行统计,cpu 是从 0(表示第一颗 cpu)开始计数。由于有些程序是单线程导致整体 cpu 占用不高,某个使用了百分之百,其他空闲着,导致程序很慢。

uptime 命令的输出,load average 三个值的大小一般不能大于 cup 个数,大于 cpu 个数说明 cpu 很忙忙负载很高,偶尔大于也不用太担心。

iostat -c 只显示 cpu 信息。

内存性能评估

free -m -s 5(m 表示以 mb 为单位显示,5 表示每隔 5 秒输出一次)

total used free shared buffers cached

Mem: 981 905 75 24 145 179

-/+ buffers/cache: 581 400

Swap: 2047 0 2047

一半情况可用内存(used +buffer+cached)/总的物理内存 >70% 说明内存重装,大于 20% 小于 70% 说明勉强够用,小于 20% 表示内存资源紧缺。

可用内存计算脚本如下:

free -m|sed -n '2p'|awk '{print ($4+$6+$7)/$2*100"%"}'

watch 是个非常有用的命令即在 watch 后面数据需要执行的命令,默认每隔 2 秒重新执行一次这个命令,watch -n 3 -d free -m,n 表示重复执行的时间间隔,d 表示高亮显示变化。

vmstat 命令也可关注内存,重点关注 swpd、si、so 参数。

sar -r 2 3 也可统计内存。不仅输出使用量还输出使用的百分比。现在内存很便宜,一般内存都很大,一半都满足要求,如出现不足都是应用程序本身造成的。

磁盘 I/O 性能评估

首先对 raid 了解不同的场景使用不同的 raid 组合方式或考虑使用裸设备(缺点是数据管理、空间管理不灵活,需要很专业的人士操作)。

sar -d 2 3

Average: DEV tps rd_sec/s wr_sec/s avgrq-sz avgqu-sz await svctm %util

Average: dev11-0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00

Average: dev8-0 2.36 0.00 32.38 13.71 0.00 2.00 0.71 0.17

Average: dev8-16 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00

%util 表示 1 秒中有百分之几的时间用来 i/o 操作。

tps 表示每秒到物理磁盘的传送数,也就是每秒的 I/O 流量。一个传送就是一个 I/O 请求,多个逻辑请求可以合并为一个物理 I/O 请求。

iostat -d 2 3

Device: tps Blk_read/s Blk_wrtn/s Blk_read Blk_wrtn

scd0 0.00 0.01 0.00 264 0

sda 1.87 15.05 39.30 561380 1466250

sdb 0.01 0.12 0.00 4586 64

iostat -x /dev/sda 2 3 对每个磁盘的单独统计。

要解决 I/O 的瓶颈,关键是要提高 I/O 子系统的执行效率。首要,要从应用程序上对磁盘读写进行优化,能够放到内存中执行的操作,尽量不要放到磁盘上。其次,对磁盘存储方式进行合理规划,选择适合自己的 RAID 存取方式。最后,在系统级别上,可以选择适合自身应用的文件系统类型,必要时使用裸设备提高读写性能。

网络性能评估

首先用 ping 检查联通性 ping 192.168.179.130

PING 192.168.179.130 (192.168.179.130) 56(84) bytes of data.

64 bytes from 192.168.179.130: icmp_seq=1 ttl=64 time=0.306 ms

64 bytes from 192.168.179.130: icmp_seq=2 ttl=64 time=0.191 ms

64 bytes from 192.168.179.130: icmp_seq=3 ttl=64 time=0.194 ms

9 packets transmitted, 9 received, 0% packet loss, time 8530ms

time 显示两台主机之间的网络延时情况,单位为毫秒,此值越大表示网络延时很大。

packet loss 表示丢包率,此值越小表示网络质量越好。

[root@ppzCentos1 ~]# netstat -i 提供网络接口的详细信息

Kernel Interface table

Iface MTU Met RX-OK RX-ERR RX-DRP RX-OVR TX-OK TX-ERR TX-DRP TX-OVR Flg

eth0 1500 0 54998 0 0 0 73183 0 0 0 BMRU

lo 65536 0 47231 0 0 0 47231 0 0 0 LRU

通信术语 最大传输单元(Maximum Transmission Unit,MTU)是指一种通信协议的某一层上面所能通过的最大数据包大小(以字节为单位)。最大传输单元这个参数通常与通信接口有关(网络接口卡、串口等)。

netstat -r/route 检查系统的路由表信息。

sar -n DEV 2 3 显示网络的运行状态。

统计网络连接数:

netstat -n|grep "ESTABLISHED"|wc -l

统计 ip 的连接数:

netstat -n|grep "ESTABLISHED"|awk -F"[ :]+" '{print $6}'|sort|uniq -c

来自 [http://blog.panwei.org/wp-admin/post.php?post=402&action=edit](http://blog.panwei.org/wp-admin/post.php?post=402&action=edit)

  • Linux

    Linux 是一套免费使用和自由传播的类 Unix 操作系统,是一个基于 POSIX 和 Unix 的多用户、多任务、支持多线程和多 CPU 的操作系统。它能运行主要的 Unix 工具软件、应用程序和网络协议,并支持 32 位和 64 位硬件。Linux 继承了 Unix 以网络为核心的设计思想,是一个性能稳定的多用户网络操作系统。

    944 引用 • 943 回帖

相关帖子

欢迎来到这里!

我们正在构建一个小众社区,大家在这里相互信任,以平等 • 自由 • 奔放的价值观进行分享交流。最终,希望大家能够找到与自己志同道合的伙伴,共同成长。

注册 关于
请输入回帖内容 ...

推荐标签 标签

  • 支付宝

    支付宝是全球领先的独立第三方支付平台,致力于为广大用户提供安全快速的电子支付/网上支付/安全支付/手机支付体验,及转账收款/水电煤缴费/信用卡还款/AA 收款等生活服务应用。

    29 引用 • 347 回帖 • 1 关注
  • 黑曜石

    黑曜石是一款强大的知识库工具,支持本地 Markdown 文件编辑,支持双向链接和关系图。

    A second brain, for you, forever.

    15 引用 • 122 回帖
  • Java

    Java 是一种可以撰写跨平台应用软件的面向对象的程序设计语言,是由 Sun Microsystems 公司于 1995 年 5 月推出的。Java 技术具有卓越的通用性、高效性、平台移植性和安全性。

    3187 引用 • 8213 回帖
  • VirtualBox

    VirtualBox 是一款开源虚拟机软件,最早由德国 Innotek 公司开发,由 Sun Microsystems 公司出品的软件,使用 Qt 编写,在 Sun 被 Oracle 收购后正式更名成 Oracle VM VirtualBox。

    10 引用 • 2 回帖 • 6 关注
  • Lute

    Lute 是一款结构化的 Markdown 引擎,支持 Go 和 JavaScript。

    25 引用 • 191 回帖 • 16 关注
  • 心情

    心是产生任何想法的源泉,心本体会陷入到对自己本体不能理解的状态中,因为心能产生任何想法,不能分出对错,不能分出自己。

    59 引用 • 369 回帖 • 1 关注
  • Ubuntu

    Ubuntu(友帮拓、优般图、乌班图)是一个以桌面应用为主的 Linux 操作系统,其名称来自非洲南部祖鲁语或豪萨语的“ubuntu”一词,意思是“人性”、“我的存在是因为大家的存在”,是非洲传统的一种价值观,类似华人社会的“仁爱”思想。Ubuntu 的目标在于为一般用户提供一个最新的、同时又相当稳定的主要由自由软件构建而成的操作系统。

    125 引用 • 169 回帖 • 1 关注
  • Logseq

    Logseq 是一个隐私优先、开源的知识库工具。

    Logseq is a joyful, open-source outliner that works on top of local plain-text Markdown and Org-mode files. Use it to write, organize and share your thoughts, keep your to-do list, and build your own digital garden.

    6 引用 • 63 回帖 • 1 关注
  • AngularJS

    AngularJS 诞生于 2009 年,由 Misko Hevery 等人创建,后为 Google 所收购。是一款优秀的前端 JS 框架,已经被用于 Google 的多款产品当中。AngularJS 有着诸多特性,最为核心的是:MVC、模块化、自动化双向数据绑定、语义化标签、依赖注入等。2.0 版本后已经改名为 Angular。

    12 引用 • 50 回帖 • 474 关注
  • Swagger

    Swagger 是一款非常流行的 API 开发工具,它遵循 OpenAPI Specification(这是一种通用的、和编程语言无关的 API 描述规范)。Swagger 贯穿整个 API 生命周期,如 API 的设计、编写文档、测试和部署。

    26 引用 • 35 回帖 • 2 关注
  • Sandbox

    如果帖子标签含有 Sandbox ,则该帖子会被视为“测试帖”,主要用于测试社区功能,排查 bug 等,该标签下内容不定期进行清理。

    407 引用 • 1246 回帖 • 581 关注
  • 30Seconds

    📙 前端知识精选集,包含 HTML、CSS、JavaScript、React、Node、安全等方面,每天仅需 30 秒。

    • 精选常见面试题,帮助您准备下一次面试
    • 精选常见交互,帮助您拥有简洁酷炫的站点
    • 精选有用的 React 片段,帮助你获取最佳实践
    • 精选常见代码集,帮助您提高打码效率
    • 整理前端界的最新资讯,邀您一同探索新世界
    488 引用 • 384 回帖 • 9 关注
  • OpenStack

    OpenStack 是一个云操作系统,通过数据中心可控制大型的计算、存储、网络等资源池。所有的管理通过前端界面管理员就可以完成,同样也可以通过 Web 接口让最终用户部署资源。

    10 引用 • 5 关注
  • 思源笔记

    思源笔记是一款隐私优先的个人知识管理系统,支持完全离线使用,同时也支持端到端加密同步。

    融合块、大纲和双向链接,重构你的思维。

    22391 引用 • 89651 回帖
  • Mac

    Mac 是苹果公司自 1984 年起以“Macintosh”开始开发的个人消费型计算机,如:iMac、Mac mini、Macbook Air、Macbook Pro、Macbook、Mac Pro 等计算机。

    166 引用 • 595 回帖 • 1 关注
  • SVN

    SVN 是 Subversion 的简称,是一个开放源代码的版本控制系统,相较于 RCS、CVS,它采用了分支管理系统,它的设计目标就是取代 CVS。

    29 引用 • 98 回帖 • 683 关注
  • 电影

    这是一个不能说的秘密。

    121 引用 • 599 回帖
  • 持续集成

    持续集成(Continuous Integration)是一种软件开发实践,即团队开发成员经常集成他们的工作,通过每个成员每天至少集成一次,也就意味着每天可能会发生多次集成。每次集成都通过自动化的构建(包括编译,发布,自动化测试)来验证,从而尽早地发现集成错误。

    15 引用 • 7 回帖 • 1 关注
  • 工具

    子曰:“工欲善其事,必先利其器。”

    286 引用 • 729 回帖
  • 前端

    前端技术一般分为前端设计和前端开发,前端设计可以理解为网站的视觉设计,前端开发则是网站的前台代码实现,包括 HTML、CSS 以及 JavaScript 等。

    247 引用 • 1348 回帖 • 2 关注
  • B3log

    B3log 是一个开源组织,名字来源于“Bulletin Board Blog”缩写,目标是将独立博客与论坛结合,形成一种新的网络社区体验,详细请看 B3log 构思。目前 B3log 已经开源了多款产品:SymSoloVditor思源笔记

    1063 引用 • 3453 回帖 • 203 关注
  • 链书

    链书(Chainbook)是 B3log 开源社区提供的区块链纸质书交易平台,通过 B3T 实现共享激励与价值链。可将你的闲置书籍上架到链书,我们共同构建这个全新的交易平台,让闲置书籍继续发挥它的价值。

    链书社

    链书目前已经下线,也许以后还有计划重制上线。

    14 引用 • 257 回帖 • 1 关注
  • OnlyOffice
    4 引用 • 3 关注
  • iOS

    iOS 是由苹果公司开发的移动操作系统,最早于 2007 年 1 月 9 日的 Macworld 大会上公布这个系统,最初是设计给 iPhone 使用的,后来陆续套用到 iPod touch、iPad 以及 Apple TV 等产品上。iOS 与苹果的 Mac OS X 操作系统一样,属于类 Unix 的商业操作系统。

    85 引用 • 139 回帖
  • 阿里云

    阿里云是阿里巴巴集团旗下公司,是全球领先的云计算及人工智能科技公司。提供云服务器、云数据库、云安全等云计算服务,以及大数据、人工智能服务、精准定制基于场景的行业解决方案。

    89 引用 • 345 回帖 • 1 关注
  • PWL

    组织简介

    用爱发电 (Programming With Love) 是一个以开源精神为核心的民间开源爱好者技术组织,“用爱发电”象征开源与贡献精神,加入组织,代表你将遵守组织的“个人开源爱好者”的各项条款。申请加入:用爱发电组织邀请帖
    用爱发电组织官网:https://programmingwithlove.stackoverflow.wiki/

    用爱发电组织的核心驱动力:

    • 遵守开源守则,体现开源&贡献精神:以分享为目的,拒绝非法牟利。
    • 自我保护:使用适当的 License 保护自己的原创作品。
    • 尊重他人:不以各种理由、各种漏洞进行未经允许的抄袭、散播、洩露;以礼相待,尊重所有对社区做出贡献的开发者;通过他人的分享习得知识,要留下足迹,表示感谢。
    • 热爱编程、热爱学习:加入组织,热爱编程是首当其要的。我们欢迎热爱讨论、分享、提问的朋友,也同样欢迎默默成就的朋友。
    • 倾听:正确并恳切对待、处理问题与建议,及时修复开源项目的 Bug ,及时与反馈者沟通。不抬杠、不无视、不辱骂。
    • 平视:不诋毁、轻视、嘲讽其他开发者,主动提出建议、施以帮助,以和谐为本。只要他人肯努力,你也可能会被昔日小看的人所超越,所以请保持谦虚。
    • 乐观且活跃:你的努力决定了你的高度。不要放弃,多年后回头俯瞰,才会发现自己已经成就往日所仰望的水平。积极地将项目开源,帮助他人学习、改进,自己也会获得相应的提升、成就与成就感。
    1 引用 • 487 回帖
  • 锤子科技

    锤子科技(Smartisan)成立于 2012 年 5 月,是一家制造移动互联网终端设备的公司,公司的使命是用完美主义的工匠精神,打造用户体验一流的数码消费类产品(智能手机为主),改善人们的生活质量。

    4 引用 • 31 回帖 • 2 关注