千家信息网

linux系统中的12条性能调优命令分别是怎么样的

发表于:2024-11-26 作者:千家信息网编辑
千家信息网最后更新 2024年11月26日,这期内容当中小编将会给大家带来有关linux系统中的12条性能调优命令分别是怎么样的,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。R:运行和等待CPU时间片的进程数
千家信息网最后更新 2024年11月26日linux系统中的12条性能调优命令分别是怎么样的

这期内容当中小编将会给大家带来有关linux系统中的12条性能调优命令分别是怎么样的,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。

R:运行和等待CPU时间片的进程数。长期大于CPU的个数,代表CPU不足
B:等待资源的进程数,如果等待数量多,问题有可能处在I/O或者内存
Swpd:切换到内存交换区的内存大小[以KB为单位]
free:当前空闲的物理内存数量[以KB为单位]
si:由磁盘调入内存
so:由内存调入磁盘
bi:从块设备读入数据的总量
bo:写到块设备的数据总量
bi+bo1000 如果超过1000,代表硬盘的读写速度有问题
in:在某一时间间隔内观测到的每秒设备中断数[中断数太多对性能不好]
cs:列表示每秒产生的上下文切换次数
us+sy > 80%代表CPU资源不足
us:用户进程消耗的CPU时间百分比
sy:内核进程消耗的CPU时间百分比
id:CPU处在空闲状态的时间百分比
wa:IO等待所占用的时间百分比
runq-sz:内存中可以运行的进程数
plist-sz:系统中活跃的任务个数

4,sar检测CPU资源:

任务计划 /etc/cron.d/sysstat日志目录 /var/log/sa查看方法 Sar -q -f /var/log/sa/sa10

5,lscpu显示CPU信息:

dmesg 显示出开机启动的信息 lscpu 显示CPU信息 lscpu -p 显示CPU对应的节点数getconf LONG_BIT 获知主机的位数 getconf -a 查看全部的参数 /sys/class/dmi/id 可以查看Bios的信息 bios_*

6,strace显示程序的调用:

strace -fc elinks -dump http://localhost

7,调优硬盘优先写入/读取数据用:


预先读取需要写入的量,然后再处理写请求,↑读到的值将会是设置值的一半↑。
设置读取到缓存中的数值越大.写入时就会因为数据量大而速度变慢。

/sys/block/sda/queue/nr_requests 队列长度越大,硬盘IO速度会提升,但占用内存
/sys/block/sda/queue/scheduler 调度算法Noop、anticipatory、deadline、[cfq]

8,将Ext3文件系统的日志功能独立:

1、创建200M的/dev/sdb1 格式化为ext32、dumpe2fs /dev/sdb1查看文件系统功能中包含的has_journal3、Tune2fs -O ^has_journal /dev/sdb1 去掉默认原有的日志功能4、再分一个200M的分区./dev/sdb2. 日志卷的block必须等于 /dev/sdb1Mke2fs -O journal_dev -b 1024 /dev/sdb25、将/dev/sdb2作为/dev/sdb1的日志卷.Tune2fs -j -J device=/dev/sdb2 /dev/sdb1

9,关闭记录文件系统atime:

对于网站文件,频繁的修改atime是没有意义的,会影响性能mount -o remount,noatime DEVICE 即可

10、修改文件日志的提交时间:

默认是5秒提交一次日志,修改更长时间可以提高性能,但容易丢失数据。mount -o remount,commit=15 DEVICE

11,RAID轮循写入调优,适用于0/5/6:

chunk size.轮循一次写入的字节.默认是64K,只要没有写满,就不会移动到下一个设备

设置在每个硬盘都只写一个文件就切换到下一块硬盘,那么如果都是1K的小文件,就会将系统资源浪费在切换硬盘上

如果将chunk size的值设置很大,比如100M,那么也就没有了意义,还不如用一块硬盘。

Stripe size.条带大小,并不是有数据就写入,而是设置每次写入的数据量,一般是16K写一次。

所以.Chunk size(64K)/stripe size(16K),也就是说每块硬盘写四次。

------------------------------------算当前应该把chunk size调成多少------------------------------------

使用iostat -x查看自开机以来每秒的平均请求数avgrq-sz
chunk size = 每秒请求数*512/1024/磁盘数,取一个最紧接2倍数的整数
stride = chunk size /block(默认是4k)

创建raid并设置chunk sinze
mdadm -C /dev/md0 -l 0 -n3 -chunk=8 /dev/sdb[123]
修改raid
mke2fs -j -b 4096 -E stride=2 /dev/md0

12,硬盘的block保留数:

 dumpe2fs /dev/sda1 tune2fs -m 10 /dev/sda1 保留block百分比 tune2fs -r 保留block数 保留的block过少,影响性能,保留的过多又浪费硬盘,默认是5%

学习了上面的性能调优命令和方法后,再总结几条调优的金句:

独立设备性能速度比集成的强,因为不占用主机整体资源
工程师一般不会远程管理计算机,需要提供日志等信息
硬盘空间越大,读取的速度越慢,可以考虑用多块硬盘组成一块较大空间
分区只是在硬盘上做标识,而不像格式化在做文件系统特性,所以速度快
硬盘越靠外侧速度越快[分区号越小越靠外区,所以将数据量大的首先分区].
程序开发者注重雇主的功能要求,系统管理员注重程序的资源开销

上述就是小编为大家分享的linux系统中的12条性能调优命令分别是怎么样的了,如果刚好有类似的疑惑,不妨参照上述分析进行理解。如果想知道更多相关知识,欢迎关注行业资讯频道。

0