Linux系统性能优化思路和方法(转)

#影响Linux性能的CPU、内存、磁盘、网络等因素分析

1.系统硬件资源:CPU,多核与超线程

消耗CPU的业务:动态WEB服务,Mail服务器

2.内存:物理内存与swap的取舍,64操作系统

消耗内存的业务:内存数据库(Redis、hbase、mongodb)

3.磁盘:RAID技术(RAID0/1/5/10),SSD

消耗磁盘的业务:数据库服务器

4.网络带宽:网卡/交换机/双网卡绑定

消耗带宽的业务:hadoop平台,视频业务平台

#影响Linux性能的操作系统相关资源分析

1.系统安装优化

磁盘分区,RAID设置,swap设置

2.内核参数优化

ulimit -n 最大打开文件数

ulimit -u 最大用户数

3.文件系统优化

ext2:linux下标准文件系统,无日志记录(inode)功能

ext3:在ext2基础上增加了日志记录功能(inode),仅支持32000个目录

ext4: ext3的后续版本,linux2.6.28内核开始支持,无限子目录支持,快速fsck

xfs:高性能文件系统,linux3.10内核开始默认支持

读操作频繁首选:ext4 写操作频繁首选:xfs

#系统性能调优之CPU性能评估工具与优化经验

1.cpu性能评估工具

vmstat(默认系统自带)

vmstat 3 5    表示每3s更新一次输出信息,统计5次后停止输出

[root@zabbix ~]# vmstat 2 3

procs -----------memory---------- ---swap-- -----io---- --system-- -----cpu-----

r  b   swpd   free   buff  cache   si   so    bi    bo   in   cs us sy id wa st

0  0      0 60072824 246332 3805844    0    0     0    25    1    1  0  0 100  0  0

1  0      0 60072848 246332 3805844    0    0     0    24  698  729  0  0 100  0  0

0  0      0 60073080 246332 3805844    0    0     0    28 1445 1034  0  0 100  0  0

procs    r列表示运行和等待cpu时间片的进程数,这个如果长期大于系统cpu个数,说明cpu不足,需要增加cpu

b列表示在等待资源的进程数,比如等待I/O,或者内存交换等

procs标准:    r 不超过cpu进程数

memory标准:

swap标准:    si,so长期不为0,说明内存不足,需要加内存

io标准:    bi+bo超过1000,而且wa值较高,说明磁盘IO有问题,应提高磁盘读写性能

system标准:    us长期超过50%,用户进程消耗cpu,需要考虑优化程序或算法

sy长期超过50%,内核消耗的cpu资源很多

us+sy长期超过80%,说明可能cpu资源部足

id cpu空闲的百分比

wa 参考值20%,如果超过20%,说明io等待严重

cpu重点参考:r    cs  us  sy id  wa值的大小

2.iostat工具(需要安装sysstat工具包)

iostat -c 3 5   显示cpu使用情况

iostat -d 3 5    显示磁盘使用情况

# -r内存,-ucpu -d磁盘

tps 表示每秒到物理磁盘的传送数,也就是每秒的I/O流量,一个传送就是一个I/O请求,多个逻辑请求可以被合并为一个物理I/O请求

sar -r 3 5

sar -u 3 5

pidstat -r -p 3 5

#系统性能调优之内存性能、磁盘性能评估工具与优化经验

#系统性能调优之网络性能评估工具与系统性能分析标准

mtr www.baidu.com

tracroute www.baidu.com

netstat -r    查看网络接口状态

netstat -i     c查看网络路由

你可能感兴趣的:(Linux系统性能优化思路和方法(转))