在对互联网服务进行服务端性能测试时,主要关注两方面的性能指标:

业务指标:如吞吐量(QPS、TPS)、响应时间(RT)、并发数、业务成功率等

资源指标:如CPU、内存、Disk I/O、Network I/O等资源的消耗情况

本文主要介绍一些广泛适用的、基本的资源指标以及这些指标在Linux服务器的获取方式。

关于CPU资源,有三个重要概念是我们需要关注的:使用率、运行队列和上下文切换。

CPU使用率(CPU Utilization Percentages):有进程处于Running状态的时间/总时间。

性能测试指标中,CPU使用率通常用us + sy来计算,其可接受上限通常在70%~80%。另外需要注意的是,在测试过程中,如果sy的值长期大于25%,应该关注in(系统中断)和cs(上下文切换)的数值,并根据被测应用的实现逻辑来分析是否合理。

运行队列进程数(Processes on run queue):Running状态 + Waiting状态的进程数,展示了正在运行和等待CPU资源的任务数,可以看作CPU的工作清单,是判断CPU资源是否成为瓶颈的重要依据。vmstat通过r的值来体现:

r: 可运行进程数,包括正在运行(Running)和已就绪等待运行(Waiting)的。

如果r的值等于系统CPU总核数,则说明CPU已经满负荷。在负载测试中,其可接受上限通常不超过CPU核数的2倍。

上下文切换(Context Switches):简单来说,context指CPU寄存器和程序计数器在某时间点的内容,(进程)上下文切换即kernel挂起一个进程并将该进程此时的状态存储到内存,然后从内存中恢复下一个要执行的进程原来的状态到寄存器,从其上次暂停的执行代码开始继续执行至频繁的上下文切换将导致sy值增长。vmstat通过cs的值来体现:

另外还有一个指标用来作为系统在一段时间内的负载情况的参考:

平均负载Load Average:在UNIX系统中,Load是对系统工作量的度量。Load取值有两种情况,多数UNIX系统取运行队列的值(vmstat输出的r),而Linux系统取运行队列的值 + 处于task_uninterruptible状态的进程数(vmstat输出的b),所以会出现CPU使用率不高但Load值很高的情况。Load Average就是在一段时间内的平均负载,系统工具top、uptime等提供1分钟、5分钟和15分钟的平均负载值。

讲到的内存,包括物理内存和虚拟内存,性能测试工具物理内存和硬盘上的一块空间(SWAP)组合起来作为虚拟内存(Virtual Memory)为进程的运行提供一个连续的内存空间,这样的好处是进程可用的内存变大了,

但需要注意的是,SWAP的读写速度远低于物理内存,并且物理内存和swap之间的数据交换会增加系统负担。虚拟内存被分成页(x86系统默认页大小为4k),内核读写虚拟内存以页为单位,当物理内存空间不足时,内存调度会将物理内存上不常使用的内存页数据存储到磁盘的SWAP空间,物理内存与swap空间之间的数据交换过程称为页面交换(Paging)。

可用内存(free memory):内存占用的直观数据,vmstat输出free的值,可用内存过小将影响整个系统的运行效率,对于稳定运行的系统,free可接受的范围通常应该大于物理内存的20%,即内存占用应该小于物理内存的80%。在压力测试时,系统内存资源的情况应该用可用内存结合页面交换情况来判断,如果可以内存很少,但页面交换也很少,此时可以认为内存资源还对系统性能构成严重影响。

页面交换(Paging):页面交换包括从SWAP交换到内存和从内存交换到SWAP,如果系统出现频繁的页面交换,需要引起注意。可以从vmstat的si和so获取:

si:每秒从SWAP读取到内存的数据大小

so:每秒从内存写入到SWAP的数据大小

SWAP空间占用:可以从vmstat的swpd来获取当前SWAP空间的使用情况,应该和页面交换结合来分析,比如当swpd不为0,但si,so持续保持为0时,内存资源并没有成为系统的瓶颈。

磁盘通常是系统中最慢的一环,一是其自身速度慢,即使是SSD,其读写速度与内存都还存在数量级的差距,二是其离CPU最远。另外需要说明的是磁盘IO分为随机IO和顺序IO两种类型,在性能测试中应该先了解被测系统是偏向哪种类型。

随机IO:随机读写数据,读写请求多,每次读写的数据量较小,其IO速度更依赖于磁盘每秒能IO次数(IOPS)。

顺序IO:顺序请求大量数据,读写请求个数相对较少,每次读写的数据量较大,顺序IO更重视每次IO的数据吞吐量。

对于磁盘,首要关注使用率,IOPS和数据吞吐量,在Linux服务区,可以使用iostat来获取这些数据。

(设备)使用率:统计过程中处理I/O请求的时间与统计时间的百分比,即iostat输出中的%util,如果该值大于60%,很可能降低系统的性能表现。

IOPS:每秒处理读/写请求的数量,即iostat输出中的r/s和w/s,个人PC的机械硬盘IOPS一般在100左右,而各种公有云/私有云的普通服务器,也只在百这个数量级。预先获取到所用服务区的IOPS能力,然后在性能测试中监控试试的IOPS数据,来衡量当前的磁盘是否能满足系统的IO需求。

数据吞吐量:每秒读/写的数据大小,即iostat输出中的rkB/s和wkB/s,通常磁盘的数据吞吐量与IO类型有直接关系,顺序IO的吞吐能力明显优与随机读写,可以预先测得磁盘在随机IO和顺序IO下的吞吐量,以便于测试时监控到的数据进行比较衡量。

服务器io性能指标,性能测试中服务器关键性能指标浅析相关推荐

  1. 服务器性能主要指标,性能测试中服务器关键性能指标浅析

    在对互联网服务进行服务端性能测试时,主要关注两方面的性能指标: 业务指标:如吞吐量(QPS.TPS).响应时间(RT).并发数.业务成功率等 资源指标:如CPU.内存.Disk I/O.Network ...

  2. 性能测试中服务器关键性能指标浅析

    业务指标:如吞吐量(QPS.TPS).响应时间(RT).并发数.业务成功率等 资源指标:如CPU.内存.Disk I/O.Network I/O等资源的消耗情况 本文主要介绍一些广泛适用的.基本的资源 ...

  3. 高性能服务器io函数,操作系统中的I/O,及高性能IO模型

    I/O(Input/Output)输入输出,总体图 一.操作系统与设备之间的IO 简单来说(详细的请看<现代操作系统>),操作系统通过设备驱动程序访问IO设备.方式有: (1)轮询方式: ...

  4. 浅谈软件性能测试中关键指标的监控与分析(转)

    浅谈软件性能测试中关键指标的监控与分析 一.软件性能测试需要监控哪些关键指标? 软件性能测试的目的主要有以下三点: Ø  评价系统当前性能,判断系统是否满足预期的性能需求. Ø  寻找软件系统可能存在 ...

  5. 项目实践:基于华为CCE环境下Tomcat的关键性能指标及监控方法

    CCE是华为公司提供的高度可扩展的.高性能的企业级Kubernetes集群,并能支持Docker容器生态. CCE可以轻松创建和管理多样化的容器工作负载,并提供容器故障自愈.监控日志采集.自动弹性扩容 ...

  6. SDN控制器关键性能指标及测试方法—Vecloud

    在SDN技术中,Controller是重中之重的产品.Controller的主要功能,通过南向接口管理下面连接的设备资源(VM.vSwitch.NFV),通过北向接口根据租户的需求,划分不同的资源给某 ...

  7. mysql单库tps_MySQL数据库三个关键性能指标--TPS\QPS\IOPS

    今天主要介绍MySQL数据库,或者说所有数据库的三个关键性能指标: qps 每秒处理的查询数 tps 每秒处理的事务数 IOPS 每秒磁盘进行的I/O操作次数 一.TPS(适用innodb) 1. 概 ...

  8. 应用程序的8个关键性能指标以及测量方法

    前言 高性能一直是我们作为程序员..孜孜不倦的追求.. 有的时候甚至会为了一句代码吵上几天.. 那么到底应该如何评估我们的性能指标来判断是否需要优化呢? 今天就来讲一下这个.. 说明一下,本篇是译文. ...

  9. 虚拟服务器 资源管理,虚拟化云计算中的资源管理策略

    虚拟化技术是云计算平台的基础,其目标是对物理计算资源进行整合或划分,自它提出之日时就获得了广泛应用,现在甚至成为云计算管理平台中的关键技术层面.按照虚拟化实现的层次,可以将其分为完全虚拟化和半虚拟化技 ...

最新文章

  1. 关于cisco与中兴三层设备ospf互连
  2. ORACLE审计初步入门
  3. EOJ_1094_寻找航海路线
  4. hibernate防止sql语句注入
  5. java读取resouces目录下文件
  6. MDK编译生成bin文件
  7. JS单曲调用百度mp3音乐播放器代码
  8. Delphi新手必看
  9. Visual Studio Developer Assistant 3月新功能展示
  10. Netty in action—Netty组件和设计
  11. COCOS2D-X 动作 CCSequence动作序列
  12. 一款短小精悍的日志分析工具web_log_analyse
  13. ueditor php提交表单,ThinkPHP使用Ueditor的方法详解
  14. Shell 脚本执行错误 $‘\r‘:command not found
  15. Python网络爬虫
  16. Python入门数学类编程——抛物运动
  17. 结果公示!400名博硕士获“优秀学位论文”奖!
  18. [转]互联网系统架构的演进
  19. 团队作业7-Alpha冲刺之事后诸葛亮
  20. 多线程_12_优先级

热门文章

  1. php似水流年同学录,似水年华同学录源码附教程
  2. 把吃出来的病吃回去 张悟本_书籍:多活几十年:把吃出来的病吃回去
  3. 超级计算机通信工程研发相关高校,美国留学签证十大常见拒签理由
  4. inventor2五子棋游戏apk_联机五子棋手机版下载|联机五子棋游戏下载v1.3.2 安卓版_ 单机手游网...
  5. 风险提醒之Oracle RAC高可用失效
  6. 深圳女子疑丈夫有外遇 捂死一双儿女
  7. C++ strcat 函数实现字符串拼接报错
  8. 未来计算机电脑发展,后PC时代 看未来计算机发展趋势
  9. HTML案例--西式甜品网
  10. 短波爱好者如何增强短波收音机接收能力