软件性能测试(连载15)

本文涉及的产品
性能测试 PTS,5000VUM额度
简介: 软件性能测试(连载15)
6)小结

本节所涉及的概念有文件储结构(包括索引节点和目录项)、虚拟文件系统VFSLinux I/O分类和磁盘的性能指标。涉及到的命令有stat dfiostat cat /proc/slabinfoslabtoppidstatiotop


4. 网络


1)网络协议栈

在大学的时候,都学过网络的协议栈。OSI7层,TCP/IP模型为4层,其对应关系如图3-32所示。


image.png

3-32  OSI 7层协议与TCP/IP模型4层协议对照表


OSI模型仅为教学提供,在日常工作中使用TCP/IP协议。在LinuxTCP网络包如图3-33所示。

image.png

3-33  Linux中的TCP网络包


在应用层仅为具体要用到的应用数据;到了传输层在头部加上TCP头信息;向下进入网络层,在TCP头信息头部再加上IP头信息;最后到达网络接口层,在数据包的头尾部各加上帧头和帧尾两部分。


TCP/IP的传输过程中,发送方从上而下一层一层地在应用数据前后加上头信息与尾信息,接受方从下而上一层一层地把头信息与尾信息去除,直到在应用层只剩下应用信息为止,如图3-34所示。


image.png

3-34  TCP/IP数据包的发送与接受


2Linux 网络栈

Linux的网络栈如图3-35所示。

image.png

3-35  Linux的网络栈


3)网络性能指标

同磁盘一样,网络也有对应的性能指标。


带宽。

表示链路的最大传输速率。单位通常为b/s(比特/秒)。

吞吐量。

表示没丢包时的最大数据传输速率。单位通常为b/s(比特/秒)或者 B/s(字节/秒),吞吐量受带宽限制,而吞吐量/带宽,也就是该网络的使用率

延时。

表示从网络请求发出后,一直到收到远端响应,所需要的时间延迟。在不同场景中,这一指标可能会有不同的含义。比如,它可以表示,建立连接需要的时间(比如 TCP 握手延时)或一个数据包往返所需的时间(比如 RTT)。

PPS

Packet PerSecond(包/秒)的缩写,表示以网络包为单位的传输速率。PPS 通常用来评估网络的转发能力,比如硬件交换机,通常可以达到线性转发(即PPS 可以达到或者接近理论最大值)。而基于Linux服务器的转发,则容易受网络包大小的影响。

网络的可用性。

网络能否正常通信

并发连接数。

TCP 的并发连接数量

丢包率。

传输过程中丢包的数量与总包的数量的百分比

重传率。

重新传输的网络数据包占所有包的百分比。


4)常用命令
ifconfig
# ifconfig ens33
ens33:flags=4163<UP,BROADCAST,RUNNING,MULTICAST>  mtu 1500
inet 192.168.0.108 netmask 255.255.255.0  broadcast192.168.0.255
inet6 fe80::dacc:9183:6dd2:2c6e  prefixlen 64 scopeid 0x20<link>
ether 00:0c:29:55:10:1f  txqueuelen 1000  (Ethernet)
RX packets 23667 bytes 34981398 (34.9 MB)
RX errors 0  dropped 0  overruns 0 frame 0
TX packets 18467 bytes 1668920 (1.6 MB)
TX errors 0 dropped 0 overruns 0  carrier0  collisions 0


ifconfiglinux中用于显示或配置网络设备(网络接口卡)的命令,英文全称是network interfaces configuring。在这里。


RUNNING

表示这个网卡是连通的。

mtu 1500

表示MTU的当前值为1500MTU为最大传输单元,其默认值为1500MTU越大,需要的分包也就越少,自然网络吞吐能力就越好。

inet 192.168.0.108  netmask255.255.255.0  broadcast 192.168.0.255

表示当前的IPv4地址,子网掩码和广播地址。

inet6 fe80::dacc:9183:6dd2:2c6e prefixlen 64  scopeid0x20

表示IPv6地址和子网掩码。


ip
# ip -s addr show dev ens33
2: ens33: <BROADCAST,MULTICAST,UP,LOWER_UP>mtu 1500 qdisc fq_codel state UP group default qlen 1000
   link/ether 00:0c:29:55:10:1f brd ff:ff:ff:ff:ff:ff
    inet192.168.0.114/24 brd 192.168.0.255 scope global dynamic noprefixroute ens33
      valid_lft 6024sec preferred_lft 6024sec
    inet6fe80::dacc:9183:6dd2:2c6e/64 scope link noprefixroute 
      valid_lft forever preferred_lft forever
    RX:bytes  packets  errors dropped overrun mcast   
   1066174744 1153443  0       0      0       0       
    TX: bytes  packets errors  dropped carrier collsns 
   313697585  701189   0      0       0       0      
root@ubuntu:/home/ebusiness#


linuxip命令和ifconfig类似,但ip功能更为强大,并旨在取代ipconfig之意。


LOWER_UP

表示这个网卡是连通的。

mtu 1500

表示MTU1500

inet 192.168.0.108/24 brd 192.168.0.255

表示当前的IPv4地址,子网掩码和广播地址。

inet6 fe80::dacc:9183:6dd2:2c6e/64 scope link noprefixroute


表示IPv6地址和子网掩码。

ifconfigip中其他参数如表3-14所示。


3-14 ifconfigip中其他参数

参数

解释

errors

发生错误的数据包的数量,比如校验错误、帧同步错误等

dropped

丢弃的数据包数,即数据包已经收到了 Ring Buffer,但因为内存不足等原因丢包

overruns

超限数据包的数量,即网络 I/O 速度过快,导致 Ring Buffer 中的数据包来不及处理(队列满)而导致的丢包

carrier

发生 carrirer 错误的数据包数,比如双工模式不匹配、物理电缆出现问题等

collisions

碰撞数据包数


sar
# sar -n DEV 1
Linux 4.15.0-66-generic (ubuntu) 12/11/2019_x86_64_(4 CPU)
12:45:31 AM  IFACE   rxpck/s txpck/s rxkB/stxkB/s rxcmp/s txcmp/s  rxmcst/s %ifutil
12:45:32 AM  ens33   0.00     0.00    0.00    0.00   0.00    0.00     0.00      0.00
12:45:32 AM  lo       0.00     0.00    0.00    0.00   0.00    0.00     0.00      0.00


sar命令配合-n参数可以查看网络的相关信息,有6个不同的开关:DEVEDEV NFSNFSDSOCKALL DEV显示网络接口信息,EDEV显示关于网络错误的统计数据,NFS统计活动的NFS客户端的信息,NFSD统计NFS服务器的信息,SOCK显示套接字信息,ALL显示所有5个开关。它们可以单独或者一起使用。这里的参数如表3-15所示。


3-15 sar -nDEV参数

参数

含义

单位

rxpck/s txpck/s

接收和发送的 PPS

/

rxkB/s txkB/s

接收和发送的吞吐量

KB/

rxcmp/s txcmp/s

接收和发送的压缩数据包数

/

%ifutil

网络接口的使用率

(rxkB/s+txkB/s)/Bandwidth(半双工模式下)

max(rxkB/s, txkB/s)/Bandwidth(全双工模式下)

Bandwidth 可以用  ethtool 来查询,它的单位通常是 Gb/s 或者 Mb/s,不过注意这里小写字母 b ,表示比特而不是字节。


ping

ping命令通过ICMP协议查看网络的连通性和延时。

# ping 192.168.0.106 -c3
PING 192.168.0.106 (192.168.0.106) 56(84) bytes ofdata.
64 bytes from 192.168.0.106: icmp_seq=1 ttl=128time=0.280 ms
64 bytes from 192.168.0.106: icmp_seq=2 ttl=128time=0.208 ms
64 bytes from 192.168.0.106: icmp_seq=3 ttl=128time=0.351 ms
--- 192.168.0.106 ping statistics ---
3 packets transmitted, 3 received, 0% packet loss,time 2007ms
rtt min/avg/max/mdev = 0.208/0.279/0.351/0.061 ms


ttl

表示生存时间,或者跳数。

time

表示往返延时。

icmp_seq

表示ICMP 序列号。

rtt min/avg/max/mdev = 0.208/0.279/0.351/0.061 ms


表示ttl的最小值为208ms、平均值为279ms、最大值为351ms以及平均偏差0.061 ms mdev = SQRT(SUM(RTT×RTT) / N – (SUM(RTT)/N) 2RTT(Round-Trip Time)。往返时延。是指数据从网络一端传到另一端所需的时间。时延由发送时延、传播时延、排队时延、处理时延四个部分组成)。


顾翔老师与云测学院联合推出:软件测试分析与设计,请点击https://v.youku.com/v_show/id_XNDQ3MzkyNjk3Ng==.html?spm=a2hzp.8244740.0.0,收看。有不同观念欢迎与顾翔老师交流!


投票已过期

1.以下你用过哪些集中配置管理系统?(多选)

  • puppet
  • Chef
  • ansible
  • saltstack
  • Cfengine
  • Capistrano
  • Resque
  • Rundeck
  • Rundeck
  • 其他

2.以下你用哪些过虚拟机或容器?(多选)

  • VMware
  • Vagrant
  • Amazon EC2
  • AMI(亚马逊云机器镜像)
  • Vagrant
  • Docker
  • Rkt
  • 裸金属服务器
  • 其他

3.以下你用哪些操作系统自动化配置工具?(多选)

  • Solaris10 JumpStart
  • Kickstart
  • Debian-Preseed
  • 其他

4.以下你用哪些云平台?(多选)

  • Amazon Web Services
  • Google App Engine
  • Windows Azure
  • OpenShift
  • Cloud Foundry
  • AWS CloudFormation
  • Microsoft Azure Stack
  • OpenStack Heat
  • 百度云
  • 阿里云
  • 腾讯云
  • 其他

5.以下你用哪些CI/CD工具?(多选)

  • Jenkins
  • ThoughtWorks GoCD
  • Atlassian Bamboo
  • Microsoft Team Foundation Server
  • TeamCity
  • GitLab CI
  • Travis CI
  • SNAP CI
  • Pivotal的Concourse
  • Etsy的Morgue
  • 其他

6.以下你用哪些管理工具?(多选)

  • JIRA
  • LeanKit
  • Mingle
  • 禅道
  • 其他

7.以下你用哪些安全工具?(多选)

  • Vault
  • Keywhiz
  • credstash
  • Red October
  • Metasploit
  • OSSEC
  • Tripwire
  • Unhide
  • OWASP ZAP Zed Attack Proxy Project
  • Lynis
  • The Browser Exploitation Framework
  • OWASP Xenotix XSS Exploit Framework
  • OWASP Offensive Testing Framework
  • Brakeman
  • WPScan
  • nmap
  • Burp Suite
  • AWVS
  • AppScan
  • CSRFTester
  • SQL Map
  • Pangolin
  • DirBuster
  • 其他

8.以下你用哪些静态扫描工具?(多选)

  • Sonar
  • Brakeman
  • Codeclimate
  • CheckStyle
  • 其他
相关实践学习
通过性能测试PTS对云服务器ECS进行规格选择与性能压测
本文为您介绍如何利用性能测试PTS对云服务器ECS进行规格选择与性能压测。
目录
相关文章
|
1月前
|
测试技术 开发者 Python
自动化测试之美:从零构建你的软件质量防线
【10月更文挑战第34天】在数字化时代的浪潮中,软件成为我们生活和工作不可或缺的一部分。然而,随着软件复杂性的增加,如何保证其质量和稳定性成为开发者面临的一大挑战。自动化测试,作为现代软件开发过程中的关键实践,不仅提高了测试效率,还确保了软件产品的质量。本文将深入浅出地介绍自动化测试的概念、重要性以及实施步骤,带领读者从零基础开始,一步步构建起属于自己的软件质量防线。通过具体实例,我们将探索如何有效地设计和执行自动化测试脚本,最终实现软件开发流程的优化和产品质量的提升。无论你是软件开发新手,还是希望提高项目质量的资深开发者,这篇文章都将为你提供宝贵的指导和启示。
|
2月前
|
机器学习/深度学习 人工智能 监控
提升软件质量的关键路径:高效测试策略与实践在软件开发的宇宙中,每一行代码都如同星辰般璀璨,而将这些星辰编织成星系的过程,则依赖于严谨而高效的测试策略。本文将引领读者探索软件测试的奥秘,揭示如何通过精心设计的测试方案,不仅提升软件的性能与稳定性,还能加速产品上市的步伐,最终实现质量与效率的双重飞跃。
在软件工程的浩瀚星海中,测试不仅是发现缺陷的放大镜,更是保障软件质量的坚固防线。本文旨在探讨一种高效且创新的软件测试策略框架,它融合了传统方法的精髓与现代技术的突破,旨在为软件开发团队提供一套系统化、可执行性强的测试指引。我们将从测试规划的起点出发,沿着测试设计、执行、反馈再到持续优化的轨迹,逐步展开论述。每一步都强调实用性与前瞻性相结合,确保测试活动能够紧跟软件开发的步伐,及时适应变化,有效应对各种挑战。
|
1月前
|
jenkins 测试技术 持续交付
自动化测试框架的构建与优化:提升软件交付效率的关键####
本文深入探讨了自动化测试框架的核心价值,通过对比传统手工测试方法的局限性,揭示了自动化测试在现代软件开发生命周期中的重要性。不同于常规摘要仅概述内容,本部分强调了自动化测试如何显著提高测试覆盖率、缩短测试周期、降低人力成本,并促进持续集成/持续部署(CI/CD)流程的实施,最终实现软件质量和开发效率的双重飞跃。通过具体案例分析,展示了从零开始构建自动化测试框架的策略与最佳实践,包括选择合适的工具、设计高效的测试用例结构、以及如何进行性能调优等关键步骤。此外,还讨论了在实施过程中可能遇到的挑战及应对策略,为读者提供了一套可操作的优化指南。 ####
|
1月前
|
机器学习/深度学习 人工智能 自然语言处理
自动化测试的新篇章:利用AI提升软件质量
【10月更文挑战第35天】在软件开发的海洋中,自动化测试犹如一艘救生艇,它帮助团队确保产品质量,同时减少人为错误。本文将探索如何通过集成人工智能(AI)技术,使自动化测试更加智能化,从而提升软件测试的效率和准确性。我们将从AI在测试用例生成、测试执行和结果分析中的应用出发,深入讨论AI如何重塑软件测试领域,并配以实际代码示例来说明这些概念。
63 3
|
2月前
|
敏捷开发 监控 jenkins
自动化测试之美:打造高效的软件质量保障体系
【10月更文挑战第20天】在软件开发的海洋中,自动化测试如同一艘精准的导航船,引领项目避开错误的礁石,驶向质量的彼岸。本文将扬帆起航,探索如何构建和实施一个高效的自动化测试体系,确保软件产品的稳定性和可靠性。我们将从测试策略的制定、工具的选择、脚本的编写,到持续集成的实施,一步步描绘出自动化测试的蓝图,让读者能够掌握这一技术的关键要素,并在自己的项目中加以应用。
38 5
|
2月前
|
测试技术
软件质量保护与测试(第2版)学习总结第十三章 集成测试
本文是《软件质量保护与测试》(第2版)第十三章的学习总结,介绍了集成测试的概念、主要任务、测试层次与原则,以及集成测试的不同策略,包括非渐增式集成和渐增式集成(自顶向下和自底向上),并通过图示详细解释了集成测试的过程。
79 1
软件质量保护与测试(第2版)学习总结第十三章 集成测试
|
2月前
|
测试技术
软件质量保护与测试(第2版)学习总结第十章 黑盒测试
本文是《软件质量保护与测试》(第2版)第十章的学习总结,介绍了黑盒测试的基本概念和方法,包括等价类划分、边界值分析和因果图法,并通过具体例子展示了如何设计测试用例来验证软件的功能性需求。
76 1
软件质量保护与测试(第2版)学习总结第十章 黑盒测试
|
2月前
|
人工智能 人机交互 数据库
软件质量保护与测试(第2版)学习总结第一章
本文是《软件质量保护与测试》(第2版)第一章的学习总结,概述了软件的特征、分类、软件工程的层次化技术、现代软件开发的变化,以及软件质量的概念和评价体系,包括黑盒、白盒和灰盒测试方法。
41 1
软件质量保护与测试(第2版)学习总结第一章
|
2月前
|
Java 测试技术 持续交付
探索自动化测试的奥秘:提升软件质量的关键
【10月更文挑战第20天】 在当今快速发展的软件行业中,自动化测试已成为确保产品质量和加速开发周期的重要工具。本文将深入探讨自动化测试的核心概念、实施策略及其对软件开发生命周期的影响,旨在为读者提供一种全面理解自动化测试的视角,并展示如何有效地将其应用于实际项目中以提高软件质量和效率。
29 2
|
2月前
|
测试技术
软件质量保护与测试(第2版)学习总结第十一章 白盒测试
本文是《软件质量保护与测试》(第2版)第十一章的学习总结,详细讲解了白盒测试中的控制流测试技术,包括语句覆盖、判断覆盖、条件覆盖、判定-条件覆盖和路径覆盖等方法,并通过具体代码示例展示了如何设计测试用例来验证程序中的不同执行路径。
72 2