ການກວດສອບການເຮັດວຽກຂອງ Linux ກັບ Vmstat ແລະ Iostat Commands


ນີ້ແມ່ນຊຸດ ຄຳ ສັ່ງແລະການຕິດຕາມການປະຕິບັດງານຂອງພວກເຮົາໃນ Linux. ທັງສອງ ຄຳ ສັ່ງ Vmstat ແລະ Iostat ແມ່ນມີຢູ່ໃນທຸກໆລະບົບປະຕິບັດການທີ່ຄ້າຍຄືກັບ Unix (Linux/Unix/FreeBSD/Solaris).

ຖ້າຄໍາສັ່ງ vmstat ແລະ iostat ບໍ່ມີຢູ່ໃນປ່ອງຂອງທ່ານ, ກະລຸນາຕິດຕັ້ງຊຸດ sysstat. ຄໍາສັ່ງ vmstat, sar ແລະ iostat ແມ່ນການເກັບກໍາຂໍ້ມູນຂອງຊຸດລວມຢູ່ໃນ sysstat - gestion de gestion system. iostat ສ້າງລາຍງານຂອງ CPU & ສະຖິຕິຂອງອຸປະກອນທັງ ໝົດ. ທ່ານອາດຈະດາວໂຫລດແລະຕິດຕັ້ງ sysstat ໂດຍໃຊ້ tarball ແຫຼ່ງຂໍ້ມູນຈາກ link sysstat, ແຕ່ພວກເຮົາແນະ ນຳ ໃຫ້ຕິດຕັ້ງຜ່ານ ຄຳ ສັ່ງ YUM.

$ sudo yum install sysstat         #CentOS and RHEL systems 
$ sudo dnf install sysstat         #Fedora 22+ systems 
$ sudo apt-get install sysstat     #Ubuntu and Debian based systems 
$ sudo pacman -S sysstat           #Arch Linux

<

  • vmstat - ຂໍ້ມູນສະຫຼຸບສັງລວມຂອງຄວາມຊົງ ຈຳ, ຂະບວນການ, ໜ້າ ຈໍແລະອື່ນໆ
  • iostat - ສູນປະມວນຜົນສູນກາງ (CPU) ສະຖິຕິແລະສະຖິຕິການປ້ອນຂໍ້ມູນ/ຜົນຜະລິດ ສຳ ລັບອຸປະກອນແລະສ່ວນປະກອບ.
  • ໃນຕົວຢ່າງຂ້າງລຸ່ມນີ້, ມີຫົກຖັນ. ຄວາມ ສຳ ຄັນຂອງຖັນແມ່ນຖືກອະທິບາຍຢູ່ໃນ ໜ້າ man ຂອງ vmstat ໃນລາຍລະອຽດ. ທົ່ງນາທີ່ ສຳ ຄັນແມ່ນບໍ່ເສຍຄ່າພາຍໃຕ້ ໜ່ວຍ ຄວາມ ຈຳ ແລະ si, ສະນັ້ນຢູ່ພາຍໃຕ້ຖັນແລກປ່ຽນປະສົບ.

     vmstat -a
    
    procs -----------memory---------- ---swap-- -----io---- --system-- -----cpu-----
     r  b   swpd   free  inact active   si   so    bi    bo   in   cs us sy id wa st
     1  0      0 810420  97380  70628    0    0   115     4   89   79  1  6 90  3  0

    <

  • <
  • ບໍ່ເສຍຄ່າ - ຈຳ ນວນພື້ນທີ່ໃນຄວາມຊົງ ຈຳ ທີ່ບໍ່ເສຍຄ່າ/ບໍ່ເຮັດວຽກ.
  • si - ປ່ຽນທຸກວິນາທີຈາກ disk ໃນ Kilo Bytes.
  • ສະນັ້ນ - ປ່ຽນທຸກວິນາທີໄປເປັນແຜ່ນໃນກິໂລໄບ.
  • ໝາຍ ເຫດ: ຖ້າທ່ານແລ່ນ vmstat ໂດຍບໍ່ມີຂໍ້ ຈຳ ກັດມັນຈະສະແດງບົດລາຍງານສະຫຼຸບນັບຕັ້ງແຕ່ເລີ່ມຕົ້ນລະບົບ.

    ດ້ວຍຄໍາສັ່ງນີ້, vmstat ປະຕິບັດທຸກໆສອງວິນາທີແລະຢຸດອັດຕະໂນມັດຫຼັງຈາກປະຕິບັດຫົກໄລຍະ.

     vmstat 2 6
    
    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 810420  22064 101368    0    0    56     3   50   57  0  3 95  2  0
     0  0      0 810412  22064 101368    0    0     0     0   16   35  0  0 100  0  0
     0  0      0 810412  22064 101368    0    0     0     0   14   35  0  0 100  0  0
     0  0      0 810412  22064 101368    0    0     0     0   17   38  0  0 100  0  0
     0  0      0 810412  22064 101368    0    0     0     0   17   35  0  0 100  0  0
     0  0      0 810412  22064 101368    0    0     0     0   18   36  0  1 100  0  0

    ຄໍາສັ່ງ vmstat ທີ່ມີ -t ພາລາມິເຕີສະແດງເວລາກັບທຸກເສັ້ນທີ່ຖືກພິມເປັນຮູບຂ້າງລຸ່ມນີ້.

    [[email  ~]$ vmstat -t 1 5
    
    procs -----------memory---------- ---swap-- -----io---- --system-- -----cpu------ ---timestamp---
     r  b   swpd   free   buff  cache   si   so    bi    bo   in   cs us sy id wa st
     0  0      0 632028  24992 192244    0    0    70     5   55   78  1  3 95  1  0        2012-09-02 14:57:18 IST
     1  0      0 632028  24992 192244    0    0     0     0  171  514  1  5 94  0  0        2012-09-02 14:57:19 IST
     1  0      0 631904  24992 192244    0    0     0     0  195  600  0  5 95  0  0        2012-09-02 14:57:20 IST
     0  0      0 631780  24992 192244    0    0     0     0  156  524  0  5 95  0  0        2012-09-02 14:57:21 IST
     1  0      0 631656  24992 192244    0    0     0     0  189  592  0  5 95  0  0        2012-09-02 14:57:22 IST

    vmstat ຄໍາສັ່ງແລະ -s ຫຼັບສະແດງສະຫຼຸບສັງລວມຂອງເຫດການຕ່າງໆແລະສະຖິຕິຄວາມຊົງຈໍາ.

    [[email  ~]$ vmstat -s
    
          1030800  total memory
           524656  used memory
           277784  active memory
           185920  inactive memory
           506144  free memory
            26864  buffer memory
           310104  swap cache
          2064376  total swap
                0  used swap
          2064376  free swap
             4539 non-nice user cpu ticks
                0 nice user cpu ticks
            11569 system cpu ticks
           329608 idle cpu ticks
             5012 IO-wait cpu ticks
               79 IRQ cpu ticks
               74 softirq cpu ticks
                0 stolen cpu ticks
           336038 pages paged in
            67945 pages paged out
                0 pages swapped in
                0 pages swapped out
           258526 interrupts
           392439 CPU context switches
       1346574857 boot time
             2309 forks

    vmstat ດ້ວຍຕົວເລືອກ -d ສະແດງສະຖິຕິທຸກແຜ່ນ.

    [[email  ~]$ vmstat -d
    
    disk- ------------reads------------ ------------writes----------- -----IO------
           total merged sectors      ms  total merged sectors      ms    cur    sec
    ram0       0      0       0       0      0      0       0       0      0      0
    ram1       0      0       0       0      0      0       0       0      0      0
    ram2       0      0       0       0      0      0       0       0      0      0
    ram3       0      0       0       0      0      0       0       0      0      0
    ram4       0      0       0       0      0      0       0       0      0      0
    ram5       0      0       0       0      0      0       0       0      0      0
    ram6       0      0       0       0      0      0       0       0      0      0
    ram7       0      0       0       0      0      0       0       0      0      0
    ram8       0      0       0       0      0      0       0       0      0      0
    ram9       0      0       0       0      0      0       0       0      0      0
    ram10      0      0       0       0      0      0       0       0      0      0
    ram11      0      0       0       0      0      0       0       0      0      0
    ram12      0      0       0       0      0      0       0       0      0      0
    ram13      0      0       0       0      0      0       0       0      0      0
    ram14      0      0       0       0      0      0       0       0      0      0
    ram15      0      0       0       0      0      0       0       0      0      0
    loop0      0      0       0       0      0      0       0       0      0      0
    loop1      0      0       0       0      0      0       0       0      0      0
    loop2      0      0       0       0      0      0       0       0      0      0
    loop3      0      0       0       0      0      0       0       0      0      0
    loop4      0      0       0       0      0      0       0       0      0      0
    loop5      0      0       0       0      0      0       0       0      0      0
    loop6      0      0       0       0      0      0       0       0      0      0
    loop7      0      0       0       0      0      0       0       0      0      0
    sr0        0      0       0       0      0      0       0       0      0      0
    sda     7712   5145  668732  409619   3282  28884  257402  644566      0    126
    dm-0   11578      0  659242 1113017  32163      0  257384 8460026      0    126
    dm-1     324      0    2592    3845      0      0       0       0      0      2

    vmstat ສະແດງສະຖິຕິຄວາມ ຈຳ ເປັນກິໂລໄບໂດຍຄ່າເລີ່ມຕົ້ນ, ແຕ່ທ່ານຍັງສາມາດສະແດງລາຍງານທີ່ມີຂະ ໜາດ ຄວາມ ຈຳ ເປັນເມກະໄບກັບການໂຕ້ຖຽງ -S M . ພິຈາລະນາຕົວຢ່າງຕໍ່ໄປນີ້.

     vmstat -S M 1 5
    
    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    346     53    476    0    0    95     8   42   55  0  2 96  2  0
     0  0      0    346     53    476    0    0     0     0   12   15  0  0 100  0  0
     0  0      0    346     53    476    0    0     0     0   32   62  0  0 100  0  0
     0  0      0    346     53    476    0    0     0     0   15   13  0  0 100  0  0
     0  0      0    346     53    476    0    0     0     0   34   61  0  1 99  0  0

    iostat ໂດຍບໍ່ມີການໂຕ້ຖຽງສະແດງສະຖິຕິຂອງ CPU ແລະ I/O ຂອງທຸກພາກສ່ວນດັ່ງທີ່ສະແດງຢູ່ດ້ານລຸ່ມ.

     iostat
    
    Linux 2.6.32-279.el6.i686 (linux-console.net)         09/03/2012      _i686_  (1 CPU)
    
    avg-cpu:  %user   %nice %system %iowait  %steal   %idle
               0.12    0.01    1.54    2.08    0.00   96.24
    
    Device:            tps   Blk_read/s   Blk_wrtn/s   Blk_read   Blk_wrtn
    sda               3.59       161.02        13.48    1086002      90882
    dm-0              5.76       159.71        13.47    1077154      90864
    dm-1              0.05         0.38         0.00       2576          0

    iostat ກັບ -c ການໂຕ້ຖຽງສະແດງພຽງແຕ່ສະຖິຕິຂອງ CPU ເທົ່າທີ່ສະແດງຢູ່ຂ້າງລຸ່ມ.

     iostat -c
    
    Linux 2.6.32-279.el6.i686 (linux-console.net)         09/03/2012      _i686_  (1 CPU)
    
    avg-cpu:  %user   %nice %system %iowait  %steal   %idle
               0.12    0.01    1.47    1.98    0.00   96.42

    iostat ກັບ -d ການໂຕ້ຖຽງສະແດງພຽງແຕ່ສະຖິຕິຂອງ I/O ຂອງສ່ວນແບ່ງທັງ ໝົດ ເທົ່າທີ່ສະແດງ.

     iostat -d
    
    Linux 2.6.32-279.el6.i686 (linux-console.net)         09/03/2012      _i686_  (1 CPU)
    
    Device:            tps   Blk_read/s   Blk_wrtn/s   Blk_read   Blk_wrtn
    sda               3.35       149.81        12.66    1086002      91746
    dm-0              5.37       148.59        12.65    1077154      91728
    dm-1              0.04         0.36         0.00       2576          0

    ໂດຍໃນຕອນຕົ້ນມັນຈະສະແດງສະຖິຕິຂອງການແບ່ງປັນທັງ ໝົດ, ດ້ວຍ -p ແລະການໂຕ້ຖຽງຊື່ຂອງອຸປະກອນຈະສະແດງສະຖິຕິ I/O ສຳ ລັບອຸປະກອນສະເພາະເທົ່ານັ້ນເທົ່າທີ່ສະແດງ.

     iostat -p sda
    
    Linux 2.6.32-279.el6.i686 (linux-console.net)         09/03/2012      _i686_  (1 CPU)
    
    avg-cpu:  %user   %nice %system %iowait  %steal   %idle
               0.11    0.01    1.44    1.92    0.00   96.52
    
    Device:            tps   Blk_read/s   Blk_wrtn/s   Blk_read   Blk_wrtn
    sda               3.32       148.52        12.55    1086002      91770
    sda1              0.07         0.56         0.00       4120         18
    sda2              3.22       147.79        12.55    1080650      91752

    ດ້ວຍພາລາມິເຕີ -N (Uppercase) ຈະສະແດງສະຖິຕິ LVM ເທົ່າທີ່ເຫັນ.

     iostat -N
    
    Linux 2.6.32-279.el6.i686 (linux-console.net)         09/03/2012      _i686_  (1 CPU)
    
    avg-cpu:  %user   %nice %system %iowait  %steal   %idle
               0.11    0.01    1.39    1.85    0.00   96.64
    
    Device:            tps   Blk_read/s   Blk_wrtn/s   Blk_read   Blk_wrtn
    sda               3.20       142.84        12.16    1086002      92466
    vg_tecmint-lv_root     5.13       141.68        12.16    1077154      92448
    vg_tecmint-lv_swap     0.04         0.34         0.00       2576          0

    ມີພາລາມິເຕີ -V (Uppercase) ສະແດງເວີຊັນຂອງ iostat ດັ່ງທີ່ສະແດງ.

     iostat -V
    
    sysstat version 9.0.4
    (C) Sebastien Godard (sysstat  orange.fr)

    ໝາຍ ເຫດ: vmstat ແລະ iostat ມີ ຈຳ ນວນຖັນແລະທຸງເຊິ່ງບໍ່ສາມາດອະທິບາຍລາຍລະອຽດໄດ້. ຖ້າທ່ານຕ້ອງການຮູ້ເພີ່ມເຕີມກ່ຽວກັບມັນທ່ານອາດຈະອ້າງເຖິງ ໜ້າ man ຂອງ vmstat ແລະ iostat. ກະລຸນາແບ່ງປັນມັນຖ້າທ່ານເຫັນວ່າບົດຂຽນນີ້ມີປະໂຫຍດຜ່ານກ່ອງ ຄຳ ເຫັນຂອງພວກເຮົາຂ້າງລຸ່ມນີ້.