怎么实现Linux系统性能测试和监控

发布时间:2022-01-26 17:25:19 作者:柒染
来源:亿速云 阅读:144

本篇文章给大家分享的是有关怎么实现Linux系统性能测试和监控,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。

性能测试([Unixbench])

 [root@localhost] $ ./Run

计算

查看当前CPU负载(uptime)

 [root@localhost] $ uptime

测试单cpu计算能力(bc)

 [root@localhost] $ time echo "scale=5000;4*a(1)" | bc -l -q

进程对内存的占用情况(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
 123
 ## 客户端
 ```clike
 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_bw

客户端进行测试网络带宽

 [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 eth2

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

以上就是怎么实现Linux系统性能测试和监控,小编相信有部分知识点可能是我们日常工作会见到或用到的。希望你能通过这篇文章学到更多知识。更多详情敬请关注亿速云行业资讯频道。

推荐阅读:
  1. jmeter性能测试并监控服务器硬件_华山
  2. 性能测试常用的监控指令 topas vmstat iostat

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

linux

上一篇:Linux下shell位置参数怎么用

下一篇:@Transactional注解怎么用

相关阅读

您好,登录后才能下订单哦!

密码登录
登录注册
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》