系统性能测试与监测工具汇总

作者: 潘晓华Michael | 来源:发表于2019-09-14 11:14 被阅读0次
瑞士军刀

计算

查看当前CPU负载(uptime)

[root@localhost] $ uptime

内存

查看当前内存使用的情况的状态(free)

[root@localhost] $ free -m

进程对内存的占用情况(pmap)

[root@localhost] $ pmap -d 35713 # 查看进程35713占用内存的情况

磁盘

磁盘IO测试(dd)

测试磁盘的IO写速度

# time dd if=/dev/zero of=test.dbf bs=8k count=300000 oflag=direct

测试磁盘的IO读速度

# dd if=test.dbf bs=8k count=300000 of=/dev/null 

表示每次写入/读取8k的数据,执行300000次

实时查看各磁盘的io(iostat)

[root@localhost] $ yum install sysstat
[root@localhost] $ iostat -x 1 100

对磁盘iops的测试(fio)

安装fio

[root@localhost] $ yum install fio

ioengine: 负载引擎,我们一般使用libaio,发起异步IO请求。
bs: IO大小
direct: 直写,绕过操作系统Cache。因为我们测试的是硬盘,而不是操作系统的Cache,所以设置为1。
rw: 读写模式,有顺序写write、顺序读read、随机写randwrite、随机读randread等。
size: 寻址空间,IO会落在 [0, size)这个区间的硬盘空间上。这是一个可以影响IOPS的参数。一般设置为硬盘的大小。
filename: 测试对象
iodepth: 队列深度,只有使用libaio时才有意义。这是一个可以影响IOPS的参数。
runtime: 测试时长

4K随机写测试

[root@localhost] $ fio -ioengine=libaio -bs=4k -direct=1 -thread -rw=randwrite -size=100G -filename=/dev/vdb 
-name="EBS 4KB randwrite test" -iodepth=32 -runtime=60

4K随机读测试

[root@localhost] $ fio -ioengine=libaio -bs=4k -direct=1 -thread -rw=randread -size=100G -filename=/dev/vdb 
-name="EBS 4KB randread test" -iodepth=8 -runtime=60

512KB顺序写测试

[root@localhost] $ fio -ioengine=libaio -bs=512k -direct=1 -thread -rw=write -size=100G -filename=/dev/vdb 
-name="EBS 512KB seqwrite test" -iodepth=64 -runtime=60

进程对磁盘的读写情况(iotop)

安装iotop

[root@localhost] $ yum install iotop

运行iotop查看进程对磁盘的读写

[root@localhost] $ iotop   #查看全部进程的磁盘读写情况
[root@localhost] $ iotop -o   #实时查看当前进程对磁盘的读写(推荐)
[root@localhost] $ iotop -p 34323   #查看进程号为34323对磁盘的读写情况

监控告警可以使用如下命令获取io的数据

[root@localhost] $ iotop -botqqq --iter=3

网络

网络测试(iperf)

启动服务端

[root@localhost] $ yum install iperf3 -y
[root@localhost] $ iperf3 -s

客户端进行测试

[root@localhost] $ yum install iperf3 -y
[root@localhost] $ iperf3 -c 10.2.2.2 -P 5

以上默认为作TCP测试,如果要UDP测试,服务端启动与客户端测试都需要加上-u

## 服务端
iperf3 -s -u
## 客户端
iperf3 -c 10.2.2.2 -P 5 -u

网络测试(qperf)

启动服务端

[root@localhost] $ yum install qperf -y
[root@localhost] $ qperf

客户端进行测试网络延时

[root@localhost] $ yum install qperf -y
[root@localhost] $ qperf 10.2.2.2 -t 100 -oo msg_size:8:256K:*2 tcp_lat

客户端进行测试网络带宽

[root@localhost] $ yum install qperf -y
[root@localhost] $ qperf 10.2.2.2 -t 100 -oo msg_size:8:256K:*2 tcp_bw

延时与带宽可以一起测试

[root@localhost] $ qperf 10.2.2.2 -t 100 -oo msg_size:8:256K:*2 tcp_bw tcp_lat

网卡流量监测(nload)

安装nload

[root@localhost] $ yum install nload

监测网卡流量输入及输出

[root@localhost] $ nload eth0 eth1

DNS服务压测工具(queryperf)

queryperf [-d datafile] [-s server_addr] [-p port] [-q num_queries]
-d: 后面接上一个文件,文件的内容是用户对DNS的请求,一行为一条请求,所以为了测试,我们可以在里面写上几千几万条。
-s: DNS服务器地址
-p: DNS服务器端口
-q: 请求多少次

使用vim命令先创建一个请求文件:vim querytest.txt

www.example.com A
example.com NS
tftp.example.com CNAME
blog.example.com A
....
# 600万行

执行测试命令

[root@localhost] $ queryperf -d querytest.txt -s 192.168.0.6

相关文章

  • 系统性能测试与监测工具汇总

    计算 查看当前CPU负载(uptime) 内存 查看当前内存使用的情况的状态(free) 进程对内存的占用情况(p...

  • 技术站点

    系统 环境 服务器mnt挂载磁盘 ubuntu系统备份恢复 性能 linux性能监测工具 linux系统级调优工具...

  • 第2章 LoadRunner介绍

    1简介 LoadRunner是一种预测系统行为和性能的负载测试工具。通过模拟上千万用户实施并发负载及实时性能监测的...

  • Loadrunner

    LoadRunner,是一种预测系统行为和性能的负载测试工具。通过以模拟上千万用户实施并发负载及实时性能监测的方式...

  • 测试汇总

    测试理论汇总 测试工具类行业 1.bugtags 性能测试 1.内存泄漏 2.卡顿

  • 软件测试教程 性能测试Loadrunner篇(一)

    本课程主要讲解性能测试以及性能测试工具Loadrunner。 系统开发完毕了,去做一下性能测试吧! 系统要验收了,...

  • sysstat——系统性能监控神器

    sysstat是一个软件包,包含监测系统性能及效率的一组工具,这些工具对于我们收集系统性能数据,比如:CPU 使用...

  • Web与App在测试上的区别

    Web与App系统测试范围 App与Web系统测试策略 App与Web系统测试工具 在测试工具链里,接口的测试工具...

  • 来吧!请白嫖!测试工作中需要的各种免费工具

    本文结合测试同学实际工作,汇总了工作所依赖的各类免费测试工具,涉及到基础办公、缺陷管理、IDE选择、性能测试工具、...

  • linux服务器监控工具的使用nmon

    一、简介 nmon是一个简单的性能监测工具,可以监测CPU、内存、网络等的使用情况。它是一个系统监视、调优、性能测...

网友评论

    本文标题:系统性能测试与监测工具汇总

    本文链接:https://www.haomeiwen.com/subject/qmnfyctx.html