當前位置:首頁 » 操作系統 » linux查看io進程

linux查看io進程

發布時間: 2022-09-12 00:49:46

linux 系統查看哪個進程佔io

lsof
是一個列出當前系統打開文件的工具。在linux環境下,任何事物都以文件的形式存在,通過文件不僅僅可以訪問常規數據,還可以訪問網路連接和硬體。
常用的參數列表
lsof
filename
顯示打開指定文件的所有進程
lsof
-a
表示兩個參數都必須滿足時才顯示結果
lsof
-c
string
顯示COMMAND列中包含指定字元的進程所有打開的文件
lsof
-u
username
顯示所屬user進程打開的文件
lsof
-g
gid
顯示歸屬gid的進程情況
lsof
+d
/DIR/
顯示目錄下被進程打開的文件
lsof
+D
/DIR/
同上,但是會搜索目錄下的所有目錄,時間相對較長
lsof
-d
FD
顯示指定文件描述符的進程
lsof
-n
不將IP轉換為hostname,預設是不加上-n參數
lsof
-i
用以顯示符合條件的進程情況
lsof
-i[46]
[protocol][@hostname|hostaddr][:service|port]
46
-->
IPv4
or
IPv6
protocol
-->
TCP
or
UDP
hostname
-->
Internet
host
name
hostaddr
-->
IPv4地址
service
-->
/etc/service中的
service
name
(可以不只一個)
port
-->
埠號
(可以不只一個)

⑵ linux系統如何查看網路IO

首先 、用top命令查看

top - 16:15:05 up 6 days, 6:25, 2 users, load average: 1.45, 1.77, 2.14

Tasks: 147 total, 1 running, 146 sleeping, 0 stopped, 0 zombie

Cpu(s): 0.2% us, 0.2% sy, 0.0% ni, 86.9% id, 12.6% wa, 0.0% hi, 0.0% si

Mem: 4037872k total, 4003648k used, 34224k free, 5512k buffers

Swap: 7164948k total, 629192k used, 6535756k free, 3511184k cached

查看12.6% wa

IO等待所佔用的CPU時間的百分比,高過30%時IO壓力高

其次、 用iostat -x 1 10

avg-cpu: %user %nice %sys %iowait %idle

0.00 0.00 0.25 33.46 66.29

Device: rrqm/s wrqm/s r/s w/s rsec/s wsec/s rkB/s wkB/s avgrq-sz avgqu-sz await svctm %util

sda 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00

sdb 0.00 1122 17.00 9.00 192.00 9216.00 96.00 4608.00 123.79 137.23 1033.43 13.17 100.10

sdc 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00

查看%util 100.10 %idle 66.29

如果 %util 接近 100%,說明產生的I/O請求太多,I/O系統已經滿負荷,該磁碟可能存在瓶頸。

idle小於70% IO壓力就較大了,一般讀取速度有較多的wait.

同時可以結合vmstat 查看查看b參數(等待資源的進程數)

vmstat -1

如果你想對硬碟做一個IO負荷的壓力測試可以用如下命令

time dd if=/dev/zero bs=1M count=2048 of=direct_2G

此命令為在當前目錄下新建一個2G的文件

我們在新建文件夾的同時來測試IO的負荷情況。

⑶ linux 怎麼查看那個進程佔用的io

ps -ef | grep 進程名稱 或者直接pgrep 進程名稱
例如mysql
ps -ef | grep mysql
pgrep mysql

⑷ 怎麼查看linux的哪個進程佔用磁碟io較多

1.使用iotop命令

使用該命令有個條件,Linux內核要高於2.6.20的版本,版本過低則沒有此命令,執行效果如下圖所示:

注意:操作完成後請關閉block_mp和啟動syslog

echo 0 > /proc/sys/vm/block_mp #關閉block_mp

/etc/init.d/syslog start #啟動syslog

⑸ linux 查看哪個進程佔用io

用 lsof 查看某塊磁碟上的讀寫進程。

gddg:~ # lsof /dev/xvda2 |head
COMMAND PID USER FD TYPE DEVICE SIZE/OFF NODE NAME
init 1 root cwd DIR 202,2 4096 2 /
init 1 root rtd DIR 202,2 4096 2 /
init 1 root txt REG 202,2 40784 193218 /sbin/init
init 1 root mem REG 202,2 19114 8063 /lib64/libdl-2.11.1.so
init 1 root mem REG 202,2 1661454 8057 /lib64/libc-2.11.1.so
init 1 root mem REG 202,2 236384 8114 /lib64/libsepol.so.1
init 1 root mem REG 202,2 113904 8115 /lib64/libselinux.so.1
init 1 root mem REG 202,2 149797 8050 /lib64/ld-2.11.1.so
kthreadd 2 root cwd DIR 202,2 4096 2 /

然後可以通過 lsof -p $pid 查看詳情

gddg:~ # lsof -p 32597
COMMAND PID USER FD TYPE DEVICE SIZE/OFF NODE NAME
bash 32597 root cwd DIR 202,2 4096 16097 /root
bash 32597 root rtd DIR 202,2 4096 2 /
bash 32597 root txt REG 202,2 584016 32203 /bin/bash
bash 32597 root mem REG 202,2 293936 8125 /lib64/libncurses.so.5.6
bash 32597 root mem REG 202,2 1661454 8057 /lib64/libc-2.11.1.so
bash 32597 root mem REG 202,2 19114 8063 /lib64/libdl-2.11.1.so
bash 32597 root mem REG 202,2 263568 8153 /lib64/libreadline.so.5.2
bash 32597 root mem REG 202,2 149797 8050 /lib64/ld-2.11.1.so
bash 32597 root mem REG 202,2 217016 16498 /var/run/nscd/passwd
bash 32597 root mem REG 202,2 256324 149503 /usr/lib/locale/en_US.utf8/LC_CTYPE
bash 32597 root mem REG 202,2 54 149490 /usr/lib/locale/en_US.utf8/LC_NUMERIC
bash 32597 root mem REG 202,2 2454 133112 /usr/lib/locale/en_US.utf8/LC_TIME
bash 32597 root mem REG 202,2 1163682 149504 /usr/lib/locale/en_US.utf8/LC_COLLATE
bash 32597 root mem REG 202,2 286 133111 /usr/lib/locale/en_US.utf8/LC_MONETARY

⑹ linux怎樣查看那個進程佔用網路io

查看linux進程佔用埠步驟如下:

  1. lsof -i 用以顯示符合條件的進程情況,lsof(list open files)是一個列出當前系統打開文件的工具。以root用戶來執行lsof -i命令,如下圖


    ⑺ 如何監測Linux進程的實時IO讀寫情況

    如何查看進程 IO 讀寫情況
    Linux Kernel 2.6.20 以上的內核支持進程 IO 統計,可以用類似 iotop 這樣的工具來監測每個進程對 IO 操作的情況,就像用 top 來實時查看進程內存、CPU 等佔用情況那樣。但是對於 2.6.20 以下的 Linux 內核版本就沒那麼幸運了,根據 Stack Overflow 的這篇回帖 給出的方法,寫了一個簡單的 python 腳本用來在 linux kernel < 2.6.20 下列印進程 IO 狀況。
    Kernel < 2.6.20

    這個腳本的想法很簡單,把 dmesg 的結果重定向到一個文件後再解析出來,每隔1秒鍾列印一次進程 IO 讀寫的統計信息,執行這個腳本需要 root:
    #!/usr/bin/python
    # Monitoring per-process disk I/O activity

    ⑻ 如何查看linux伺服器io讀寫情況

    首先 、用top命令查看
    top - 16:15:05 up 6 days, 6:25, 2 users, load average: 1.45, 1.77, 2.14
    Tasks: 147 total, 1 running, 146 sleeping, 0 stopped, 0 zombie
    Cpu(s): 0.2% us, 0.2% sy, 0.0% ni, 86.9% id, 12.6% wa, 0.0% hi, 0.0% si
    Mem: 4037872k total, 4003648k used, 34224k free, 5512k buffers
    Swap: 7164948k total, 629192k used, 6535756k free, 3511184k cached
    查看12.6% wa
    IO等待所佔用的CPU時間的百分比,高過30%時IO壓力高
    其次、 用iostat -x 1 10
    avg-cpu: %user %nice %sys %iowait %idle
    0.00 0.00 0.25 33.46 66.29
    Device: rrqm/s wrqm/s r/s w/s rsec/s wsec/s rkB/s wkB/s avgrq-sz avgqu-sz await svctm %util
    sda 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00
    sdb 0.00 1122 17.00 9.00 192.00 9216.00 96.00 4608.00 123.79 137.23 1033.43 13.17 100.10
    sdc 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00

    查看%util 100.10 %idle 66.29
    如果 %util 接近 100%,說明產生的I/O請求太多,I/O系統已經滿負荷,該磁碟可能存在瓶頸。
    idle小於70% IO壓力就較大了,一般讀取速度有較多的wait.
    同時可以結合vmstat 查看查看b參數(等待資源的進程數)
    vmstat -1
    如果你想對硬碟做一個IO負荷的壓力測試可以用如下命令
    time dd if=/dev/zero bs=1M count=2048 of=direct_2G
    此命令為在當前目錄下新建一個2G的文件
    我們在新建文件夾的同時來測試IO的負荷情況

    ⑼ linux下有沒有查看某個進程的IO的工具

    你可以試試用ps命令,以下為常用,具體用法可以網路

    1

    #> ps aux

    可以比較詳細的顯示進程信息
    同時也可在此命令後使用管道符號「|」跟上grep搜索關鍵字相關進程

    ⑽ 如何找出Linux系統高IO的思路總結

    前言

    I/O Wait是一個需要使用高級的工具來debug問題原因,當然也有許多基本工具的高級用法。I/O wait的問題難以定位的原因是:因為我們有很多工具可以告訴你I/O 受限了,但是並沒有告訴你具體是哪個進程引起的。

    1. 如何確認,是否是I/O問題導致系統緩慢

    確認是否是I/O導致的系統緩慢我們可以使用多個命令,但是,最簡單的是unix的命令 top

    # top

    top - 14:31:20 up 35 min, 4 users, load average: 2.25, 1.74, 1.68

    Tasks: 71 total, 1 running, 70 sleeping, 0 stopped, 0 zombie

    Cpu(s): 2.3%us, 1.7%sy, 0.0%ni, 0.0%id, 96.0%wa, 0.0%hi, 0.0%si, 0.0%st

    Mem: 245440k total, 241004k used, 4436k free, 496k buffers

    Swap: 409596k total, 5436k used, 404160k free, 182812k cached

    從CPU這行,可以發現CPU的io wait;這里是96.0%。越高就代表CPU用於io wait的資源越多。

    2. 找出哪個磁碟正在被寫入

    上邊的top命令從一個整體上說明了I/O wait,但是並沒有說明是哪塊磁碟影響的,想知道是哪塊磁碟引發的問題,可以使用另外一個命令 iostat 命令

    $ iostat -x 2 5

    avg-cpu: %user %nice %system %iowait %steal %idle

      3.66 0.00 47.64 48.69 0.00 0.00

    Device: rrqm/s wrqm/s r/s w/s rkB/s wkB/s avgrq-sz avgqu-sz await r_await w_await svctm %util

    sda 44.50 39.27 117.28 29.32 11220.94 13126.70 332.17 65.77 462.79 9.80 2274.71 7.60 111.41

    dm-0 0.00 0.00 83.25 9.95 10515.18 4295.29 317.84 57.01 648.54 16.73 5935.79 11.48 107.02

    dm-1 0.00 0.00 57.07 40.84 228.27 163.35 8.00 93.84 979.61 13.94 2329.08 10.93 107.02

    iostat 會每2秒更新一次,一共列印5次信息, -x 的選項是列印出擴展信息

    第一個iostat 報告會列印出系統最後一次啟動後的統計信息,這也就是說,在多數情況下,第一個列印出來的信息應該被忽略,剩下的報告,都是基於上一次間隔的時間。舉例子來說,這個命令會列印5次,第二次的報告是從第一次報告出來一個後的統計信息,第三次是基於第二次 ,依次類推

    所以,一定記住:第一個忽略!

    在上面的例子中,sda的%utilized 是111.41%,這個很好的說明了有進程正在寫入到sda磁碟中。

    除了%utilized 外,我們可以從iostat得到更加豐富的資源信息,例如每毫秒讀寫請求(rrqm/s & wrqm/s)),每秒讀寫的((r/s & w/s)。在上邊的例子中,我們的項目看起來正在讀寫非常多的信息。這個對我們查找相應的進程非常有用。

    3. 找出導致高IO的進程

    # iotop

    Total DISK READ: 8.00 M/s | Total DISK WRITE: 20.36 M/s

      TID PRIO USER DISK READ DISK WRITE SWAPIN IO> COMMAND

    15758 be/4 root 7.99 M/s 8.01 M/s 0.00 % 61.97 % bonnie++ -n 0 -u 0 -r 239 -s 478 -f -b -d /tmp

    最簡單的方法就是用iotop找出哪個進程用了最多的存儲資源,從上面可以看到是bonnie++。

    iotop很好用,但是不是默認安裝的。

    如果沒有iotop,下面的方式也可以讓你有種方法縮小范圍,盡快找到是哪個進程。

    ps 命令對內存和CPU有一個統計,但是他沒有對磁碟I/O的統計,雖然他沒有顯示磁碟I/O,但是它顯示進行的狀態,我們可以用來知道一個進程是否正在等待I/O

    主要的進程狀態有:

    PROCESS STATE CODES

    D uninterruptible sleep (usually IO)

    R running or runnable (on run queue)

    S interruptible sleep (waiting for an event to complete)

    T stopped, either by a job control signal or because it is being traced.

    W paging (not valid since the 2.6.xx kernel)

    X dead (should never be seen)

    Z defunct ("zombie") process, terminated but not reaped by its parent.

    等待I/O的進程的狀態一般是「uninterruptible sleep」,或者「D」,我們可以很容易的查找到正在等待I/O的進程

    # for x in `seq 1 1 10`; do ps -eo state,pid,cmd | grep "^D"; echo "----"; sleep 5; done

    D 248 [jbd2/dm-0-8]

    D 16528 bonnie++ -n 0 -u 0 -r 239 -s 478 -f -b -d /tmp

    ----

    D 22 [kswapd0]

    D 16528 bonnie++ -n 0 -u 0 -r 239 -s 478 -f -b -d /tmp

    ----

    D 22 [kswapd0]

    D 16528 bonnie++ -n 0 -u 0 -r 239 -s 478 -f -b -d /tmp

    ----

    D 22 [kswapd0]

    D 16528 bonnie++ -n 0 -u 0 -r 239 -s 478 -f -b -d /tmp

    ----

    D 16528 bonnie++ -n 0 -u 0 -r 239 -s 478 -f -b -d /tmp

    上邊的例子會循環的輸出狀態是D的進程,每5秒一次,一共10次

    從輸出我們可以知道 bonnie++ 的pid是16528 ,在waiting,bonnie++看起來就是我們想找到的進程,但是,只是從它的狀態,我們沒有辦法證明就是bonnie++引起的I/O等待。

    為了證明,我們可以可以查看/proc,每個進程目錄下都有一個叫io的文件,里邊保存這和iotop類似的信息。

    # cat /proc/16528/io

    rchar: 48752567

    wchar: 549961789

    syscr: 5967

    syscw: 67138

    read_bytes: 49020928

    write_bytes: 549961728

    cancelled_write_bytes: 0

    read_bytes和write_bytes是這個進程從磁碟讀寫的位元組,在這個例子中,bonnie++進程讀取了46M的數據並且寫入了524MB的數據到磁碟上。

    4. 找出哪個文件正在被大量寫入

    lsof 命令可以展示一個進程打開的所有文件。從這個列表中,我們可以找到哪個文件被寫入。

    # lsof -p 16528

    COMMAND PID USER FD TYPE DEVICE SIZE/OFF NODE NAME

    bonnie++ 16528 root cwd DIR 252,0 4096 130597 /tmp

    <truncated>

    bonnie++ 16528 root 8u REG 252,0 501219328 131869 /tmp/Bonnie.16528

    bonnie++ 16528 root 9u REG 252,0 501219328 131869 /tmp/Bonnie.16528

    bonnie++ 16528 root 10u REG 252,0 501219328 131869 /tmp/Bonnie.16528

    bonnie++ 16528 root 11u REG 252,0 501219328 131869 /tmp/Bonnie.16528

    bonnie++ 16528 root 12u REG 252,0 501219328 131869 <strong>/tmp/Bonnie.16528</strong>

    # df /tmp

    Filesystem 1K-blocks Used Available Use% Mounted on

    /dev/mapper/workstation-root 7667140 2628608 4653920 37% /

    # pvdisplay

      --- Physical volume ---

      PV Name /dev/sda5

      VG Name workstation

      PV Size 7.76 GiB / not usable 2.00 MiB

      Allocatable yes

      PE Size 4.00 MiB

      Total PE 1986

      Free PE 8

      Allocated PE 1978

      PV UUID CLbABb-GcLB-l5z3-TCj3-IOK3-SQ2p-RDPW5S

    使用pvdisplay可以看到,pv設備就是/dev/sda5,正是我們前面找到的sda。

    參考文檔:http://bencane.com/2012/08/06/troubleshooting-high-io-wait-in-linux/

熱點內容
怎麼查看泰拉伺服器ip 發布:2025-05-14 23:03:29 瀏覽:72
c語言學生成績查詢系統 發布:2025-05-14 22:58:30 瀏覽:4
怎麼進別人的伺服器 發布:2025-05-14 22:45:55 瀏覽:772
用編程寫音樂 發布:2025-05-14 22:45:08 瀏覽:782
如何識別電腦的網路配置 發布:2025-05-14 22:38:46 瀏覽:847
pipforpython3 發布:2025-05-14 22:38:34 瀏覽:350
如何把迷你世界的伺服器搞崩 發布:2025-05-14 22:37:15 瀏覽:94
如何讓安卓卡死機 發布:2025-05-14 22:36:27 瀏覽:634
wemall微商城源碼 發布:2025-05-14 22:15:20 瀏覽:804
隆地優選交易密碼是什麼 發布:2025-05-14 21:53:23 瀏覽:97