文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

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

2023-06-28 13:12

关注

本篇文章给大家分享的是有关怎么实现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系统性能测试和监控,小编相信有部分知识点可能是我们日常工作会见到或用到的。希望你能通过这篇文章学到更多知识。更多详情敬请关注编程网行业资讯频道。

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-人工智能
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯