## [重讀分區表][6]
## 磁盤類型判定 SSD HDD
~~~
SSD是非轉動磁盤, Linux可以通過讀 sysfs:
cat /sys/block/sda/queue/rotational
返回 0, 就是 SSD。
$ lsblk -d -o name,rota
NAME ROTA
sda 0
~~~
# 性能測試
## dd 簡單測試磁盤
~~~
dd if=/dev/zero of=testf bs=1M count=512 oflag=direct
# 清除cache
echo 3 > /proc/sys/vm/drop_caches
~~~
## hdparm
### 安裝
```
# centos
yum install -y hdparm
```
### 常用參數
~~~
hdparm -t /dev/sdb 測試實際磁盤性能
hdparm -T /dev/sdb 內存緩存的讀寫速度
hdparm -I /dev/sdb 查看信息
~~~
## [fio][2]
[參考博客][4]
[云盤性能測試][7]
### 安裝
~~~
yum install -y fio
~~~
### 常用參數
## bonnie++
~~~
yum install bonnie++
# 進行4G文件測試
bonnie++ -u root
~~~
```
fio -filename=/nfsdata/test_randread -direct=1 -iodepth 1 -thread -rw=randread -ioengine=psync \
-bs=512k -size=512m -numjobs=8 -runtime=60 -group_reporting -name=mytest
說明:
filename=/dev/sdb1 測試文件名稱,通常選擇需要測試的盤的data目錄。
direct=1 測試過程繞過機器自帶的buffer。使測試結果更真實。
rw=randwrite 測試隨機寫的I/O
rw=randrw 測試隨機寫和讀的I/O
bs=16k 單次io的塊文件大小為16k
bsrange=512-2048 同上,提定數據塊的大小范圍
size=5g 本次的測試文件大小為5g,以每次4k的io進行測試。
numjobs=30 本次的測試線程為30.
runtime=1000 測試時間為1000秒,如果不寫則一直將5g文件分4k每次寫完為止。
ioengine=psync io引擎使用pync方式
rwmixwrite=30 在混合讀寫的模式下,寫占30%
group_reporting 關于顯示結果的,匯總每個進程的信息。
```
## [iozone][3]
針對文件系統的性能測試的。和常用的IO性能測試工具sysbench, fio, iometer不同, 它主要是通過`模擬用戶訪問文件模式`的不同,典型的如下面的幾種:
~~~
(0=write/rewrite, 1=read/re-read, 2=random-read/write
3=Read-backwards, 4=Re-write-record, 5=stride-read, 6=fwrite/re-fwrite
7=fread/Re-fread, 8=random_mix, 9=pwrite/Re-pwrite, 10=pread/Re-pread
11=pwritev/Re-pwritev, 12=preadv/Re-preadv)
~~~
~~~
/opt/iozone/bin/iozone -l 4 -u 4 -r 512k -s 512m
~~~
來達到隔離訪問文件系統的meta信息和data信息的不同的開銷, 從而反應文件系統的性能。
* [文件系統性能測試:使用iozone](https://www.cnblogs.com/yunnotes/archive/2013/04/19/3032487.html)
### 安裝
~~~
apt-get install iozone3
yum install iozone -y
~~~
~~~
/opt/iozone/bin/iozone -i 0 -i 1 -s 512m -r 512k -I -p -t 16
-a auto mode產生文件大小16K-512M,記錄大小4K-16M的輸出結果;
-e 計算時間時算上fflush,fsync的時間;
-f 指定臨時測試文件;
-s 指定測試文件大小;
-r 指定測試記錄大小;
-g –n 指定auto模式下,最大/小測試文件大小;
-q –y 指定auto模式下,最大/小測試記錄大小;
-i 指定特定的測試操作:
-I 指定direct io操作;
-p 清除cpu cache影響;
-O 輸出IOPS值;
-R 生成excel報告文件;
-W 讀寫之前鎖定文件;
~~~
> /opt/iozone/bin/iozone -a 自動模式
# 狀態監控
## [iostat][1]
### 安裝
~~~
yum install -y sysstat
~~~
### 用法
~~~
-x 參數,輸出更多詳細信息
~~~
~~~
rrqm/s:每秒這個設備相關的讀取請求有多少被Merge了(當系統調用需要讀取數據的時候,VFS將請求發到各個FS,如果FS發現不同的讀取請求讀取的是相同Block的數據,FS會將這個請求合并Merge);
wrqm/s:每秒這個設備相關的寫入請求有多少被Merge了。
rsec/s:每秒讀取的扇區數;
wsec/:每秒寫入的扇區數。
r/s:The number of read requests that were issued to the device per second;
w/s:The number of write requests that were issued to the device per second;
await:每一個IO請求的處理的平均時間(單位是毫秒)。這里可以理解為IO的響應時間,一般地系統IO響應時間應該低于5ms,如果大于10ms就比較大了。
%util:在統計時間內所有處理IO時間,除以總共統計時間。例如,如果統計間隔1秒,該設備有0.8秒在處理IO,而0.2秒閑置,那么該設備的%util = 0.8/1 = 80%,所以該參數暗示了設備的繁忙程度。一般地,如果該參數是100%表示設備已經接近滿負荷運行了(當然如果是多磁盤,即使%util是100%,因為磁盤的并發能力,所以磁盤使用未必就到了瓶頸)。
~~~
### 實例
~~~
iostat -d -k 1 10 #查看TPS和吞吐量信息
iostat -d -x -k 1 10 #查看設備使用率(%util)、響應時間(await)
iostat -c 1 10
~~~
## [iotop][5]
## 相關博客
* [linux系統讀寫緩存](https://www.cnblogs.com/zengkefu/p/5759335.html)
[1]:http://www.cnblogs.com/muahao/p/6438409.html
[2]:http://freshmeat.sourceforge.net/projects/fio/
[3]:http://www.iozone.org/
[4]:http://elf8848.iteye.com/blog/2168876
[5]:http://guichaz.free.fr/iotop/
[6]:http://blog.chinaunix.net/uid-25906175-id-3251710.html
[7]:https://www.cnblogs.com/yuhaohao/p/9770701.html
- 目錄
- 離散的內容
- IO模型
- 網卡綁定
- ssh
- 硬件測試
- 硬件
- limits
- 網絡流量
- 硬盤IO
- 硬盤
- tmux
- 主機名和域名
- http_proxy
- iptables
- 內核參數
- 塊設備和字符設備
- 內存
- 虛擬內存并非交換分區
- 網絡延時
- 概念
- 多核壓縮
- linux基礎
- SSH協議
- 軟件管理
- yum
- 制作本地源 yum系列
- 制作本地源 apt系列
- apt
- 在 Linux 中移除從源代碼安裝的程序的一種簡單的方法
- 其他
- 源碼編譯和二進制安裝后更改配置
- DNS
- bind
- 守護進程
- 特殊權限
- limit.conf配置
- 網絡
- shell-ok
- 變量ok
- 數組ok
- 系統變量和環境變量
- 運算符和計算-ok
- 條件測試-ok
- 選擇-ok
- shell循環-ok
- 輸出echo和printf-ok
- 技巧-ok
- pre-web
- http協議
- web服務器
- Apache
- apache安裝
- yum安裝
- 二進制安裝
- 編譯安裝
- httpd命令
- 運行 監控apache
- apache配置文件
- 常用配置
- MPM多處理模塊
- 編譯模塊
- apache模塊
- apache核心模塊
- apache標準模塊
- apache第三方模塊
- 虛擬主機
- 1
- CGI-FastCGI-SSI
- 別名和重定向
- apache應用
- 301重定向
- apache防盜鏈
- http轉化為https
- 訪問時間段控制
- 控制訪問目錄
- 限制指定USER_AGENT
- 不同客戶端訪問不同網頁
- apache黑名單
- httpd之禁止解析php
- 不記錄css/js/img的訪問日志
- 瀏覽器端靜態緩存
- apache訪問日志自動切割
- order-require
- 壓縮傳輸
- httpd-ssl
- apache代理
- 正向代理
- 反向代理
- apache調優
- httpd壓力測試工具ab
- CGI測試
- php
- php原理
- httpd和php的結合方式
- php yum安裝之DSO模式
- php 編譯安裝之DSO模式
- php-fpm詳解
- php yum安裝之php-fpm模式
- php 編譯安裝之FastCGI模式
- php擴展之mysql
- php擴展之gd
- php擴展之pcntl
- php擴展之xcache
- php擴展之ZendGuardLoader
- phpMyAdmin
- wordpress
- 數據庫-mysql
- 數據庫原理
- mysql數據庫原理
- mysql源碼編譯安裝
- mysql二進制包安裝
- mysql命令行工具
- 更改密碼
- 數據庫授權grant
- mysql日志
- 命令
- 常用
- 小命令大作為
- awk 報告生成器
- 網絡命令
- 命令查找
- 壓縮歸檔命令
- 文件管理
- 文件管理命令
- 文件查看命令
- 目錄管理命令
- 用戶管理命令
- 用戶權限管理
- curl
- cheat
- chrony
- command
- crontab任務計劃
- cut
- date
- dd
- df
- echo
- find
- grep
- hash
- iftop
- kill pkill killall
- ls
- lsmod和modprobe
- lsof
- man
- mkpasswd
- mount
- mtr
- netstat
- nmap
- nc
- NTP
- passwd
- rm
- rdate
- pv
- sar系統活動情況報告
- sed文本處理命令
- setup
- screen
- shutdown
- sort 命令
- sudo
- tcpdump
- top
- uniq
- wget
- who
- xargs
- 監控
- zabbix郵件報警
- Redis
- redis安裝
- redis數據類型和操作方法
- redis持久化和配置
- redis主從配置
- php連接redis
- redis實現session共享
- 安裝測試
- redis設置密碼
- ELK日志分析系統
- elasticsearch
- logstash
- logstash插件
- filebeat日志收集
- kibana
- jenkins
- jenkins安裝與配置
- 案例1
- 案例2
- 案例3
- 代碼倉庫之svn
- svn服務端配置
- 常用操作
- svn備份
- LB集群
- LVS負載均衡集群
- ipvsadm使用方法
- LVS調度方法
- NAT原理
- NAT實踐
- DR原理
- DR實踐
- TUN原理
- LVS持久連接
- HA集群
- HPC集群
- 共享存儲
- ftp協議
- vsftpd
- NFS
- 網站架構發展
- 文件同步
- rsync基本用法
- rsync安裝和使用_拉取模式
- lsyncd安裝和用法
- zabbix
- zabbix服務端安裝
- zabbix客戶端安裝
- zabbix編譯安裝
- zabbix監控tomcat
- zabbix監控mysql
- gitlab
- supervisor
- nsq
- ruby
- nodejs
- consul
- mesos
- zookeeper
- rwho
- 對象存儲
- 工具
- rclone
- minio
- linux 性能調優
- CPU
- 第一部分 CPU
- 安全