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查看网络路由

 

 

posted @ 2017-01-02 21:22  sunmmi  阅读(5147)  评论(0编辑  收藏  举报