プロセスステータスのトップビュー
1.topコマンドの紹介
運用保守担当者なら誰しも、サーバーの負荷が急激に上昇するような事態に遭遇したことがあると思いますが、このような状況に遭遇した場合、誰もが最初にサーバーにログインし、top コマンドを入力して負荷平均を確認することになるはずです。Linux オペレーティング システムでは、top は比較的完全な情報を備えた最も頻繁に使用されるコマンドであり、システム負荷、CPU 使用率の分布、メモリ使用量、リソースなどの各情報を含む、実行中のすべてのプロセスとシステム負荷の概要情報を継続的に更新します。各プロセスの使用法. 今日の記事では、top コマンドを理解する方法を説明します。
2. topコマンドの出力結果の解析
top コマンドを実行すると、デフォルトで次の内容が表示されます:
top コマンドは多くのパラメータを出力します。他のパラメータとともに実際のサーバーの負荷を確認する必要があります。実行結果は 2 つの部分に分けることができます: 最初の
部分最初の5行がシステム全体の統計情報、
8行目からがプロセス情報です。上から順に1行ずつ説明していきます。
2.1. システム全体の統計情報
最初の行:
top - 16:20:38 up 12 days, 5:24, 2 users, load average: 0.04, 0.03, 0.05
分野 | 説明する |
---|---|
上 | 現在の時刻 |
上 | 機械はどれくらい稼働していますか? |
ユーザー | 現在のログインユーザー数 |
負荷平均 | システム負荷。タスクキューの平均長です。3つの値は1分前、5分前、15分前から現在までの平均値です。 |
二行目:
Tasks: 127 total, 1 running, 126 sleeping, 0 stopped, 0 zombie
分野 | 説明する |
---|---|
タスク数:合計356件 | システム内のプロセスの総数 |
2 ランニング | 実行中のプロセスの数。ここで実行する量が増えると、当然サーバーへの負荷も大きくなります。 |
354 寝てる | スリープ中のプロセスの数 |
0 停止しました | プロセス数を止める方法 |
0 ゾンビ | ゾンビプロセスの数。0 でない場合は、ゾンビ プロセスを手動で確認する必要があります。 |
3行目:
%Cpu(s): 0.3 us, 0.7 sy, 0.0 ni, 99.0 id, 0.0 wa, 0.0 hi, 0.0si, 0.0 st
分野 | 説明する |
---|---|
%Cpu: 0.1%us | CPU 内のユーザー空間の割合 (シェル プログラム、さまざまな言語のコンパイラー、さまざまなアプリケーション、Web サーバー、およびさまざまなデスクトップ アプリケーションなどは、すべてユーザー アドレス空間で実行されているプロセスです。これらのプログラムがアイドル状態でない場合、ほとんどのプロセスはCPU 時間のほとんどはユーザー モードで実行されます) |
0.1%と | CPU 内のカーネル領域のパーセンテージ (プロセスによって使用されるすべてのシステム リソースは Linux カーネルによって処理されます。オペレーティング システムの設計では、カーネル状態で費やされる時間はできるだけ少なくする必要があります。実際には、典型的な状況では sy が大きくなり、多数の IO 操作が発生するため、IO 関連の問題を調査するときはそれに焦点を当てる必要があります) |
0.0%です | ユーザープロセス空間の優先順位が変更されました(niはniceの略称です。niceの値によってプロセスのユーザー状態の優先順位を調整できます。ここで表示されるniは、niceを調整したプロセスが消費したCPU時間を表します)システム内のプロセスが調整されていない場合、nice 値を超えた場合、ni は 0 と表示されます) |
99.7% ID | アイドル状態の CPU 使用率 |
0.1% | 入出力を待機している CPU 時間の割合 (CPU の処理速度と比較すると、ディスク IO 操作は非常に遅いです。このような操作は数多くあります。たとえば、CPU がディスクの読み取りおよび書き込み操作を開始した後、待機する必要があります)ディスクの読み取りおよび書き込み操作の結果について。ディスクの読み取りおよび書き込み操作が完了するまで、CPU はアイドル状態にしかなりません。システムの平均負荷を計算するとき、Linux システムは、ディスクの読み取りおよび書き込み操作が完了するまでの時間も含めます。 CPU は IO 操作を待機するため、システムの平均負荷が高すぎることがわかった場合は、wa を渡して、システムのパフォーマンスのボトルネックが過剰な IO 操作によって引き起こされているかどうかを判断できます。 |
0.0% こんにちは | ハード割り込みが占める割合 (ハード割り込みは、ハードディスクやネットワーク カードなどのハードウェア デバイスによって CPU に送信される割り込みメッセージです。CPU は割り込みメッセージを受信すると、適切な処理を実行する必要があります (CPU 時間を消費します)。 |
0.1%と | ソフト割り込み占有率(ソフト割り込みはプログラムによって発行される割り込みであり、最終的には対応する処理プログラムが実行され、CPU時間を消費します) |
0.0%st | st (スチールタイム) は仮想時間の割合を意味します。これは、仮想マシンが存在する場合に、仮想 CPU が実際の CPU を待機する時間の割合です。 |
4行目: |
KiB Mem : 1863012 total, 1286408 free, 216532 used, 360072 buff/cache
分野 | コンテンツ |
---|---|
KiB メモリ: 合計 9280308 | 物理メモリの合計量 (KB) |
211208無料 | 空き物理メモリの量。 |
5943424 中古 | 使用される物理メモリの量 |
3126676 バフ/キャッシュ | カーネルキャッシュとして使用されるメモリの量 |
5行目:
KiB Swap: 5242876 total, 7999484 free, 0 used. 1468240 avail Mem
表示されるのはスワップパーティションの使用量なので、先頭コマンドを読み込むときにスワップメモリ機能がオフになっていない場合は注意が必要で、値が変化し続ける場合は本当にメモリが不足していることになります。
分野 | コンテンツ |
---|---|
KiBスワップ:合計0 | スワップパーティション(仮想メモリ)の総量 |
0 無料 | 空きスワップ パーティションのサイズ |
0 使用済み | 使用されるスワップ パーティションのサイズ |
2928776 利用可能メモリ | バッファリングされたスワップ領域の合計量 |
2.2. プロセス情報
PID USER PR NI VIRT RES SHR S %CPU %MEM TIME+ COMMAND
21829 root 20 0 0 0 0 S 0.7 0.6 129:53.91 java
22559 root 20 0 158920 5628 4268 S 0.3 9.2 139:42.81 java
22598 root 20 0 162112 2208 1540 S 0.3 0.1 0:04.68 fluentd
PID 进程id
USER 进程所有者的用户名
PR 优先级
NI nice值,负值表示高优先级,正值表示低优先级
VIRT 进程使用的虚拟内存总量,单位kb。VIRT=SWAP+RES
RES 进程使用的、未被换出的物理内存大小,单位kb。RES=CODE+DATA
SHR 共享内存大小,单位kb
S 进程状态。D=不可中断的睡眠状态 R=运行 S=睡眠 T=跟踪/停止 Z=僵尸进程
%CPU 上次更新到现在的CPU时间占用百分比
%MEM 进程使用的物理内存百分比
TIME+ 进程使用的CPU时间总计,单位1/100秒
COMMAND 命令名/命令行
デフォルトでは、より重要な PID、USER、PR、NI、VIRT、RES、SHR、S、%CPU、%MEM、TIME+、COMMAND 列と、次のようないくつかのパラメータのみが表示されます。
PPID 父进程id
GROUP 进程所有者的组名
SWAP: 进程使用的虚拟内存中被换出的大小
CODE 可执行代码占用的物理内存大小,单位kb
DATA 可执行代码以外的部分(数据段+栈)占用的物理内存大小,单位kb
nFLT 页面错误次数
nDRT 最后一次写入到现在,被修改过的页面数。
WCHAN 若该进程在睡眠,则显示睡眠中的系统函数名
Flags 任务标志
3.topコマンドの使用方法
3.1 表示内容の変更
f キーを押すと、表示内容を編集できます。 f キーを押すと、次の図が表示されます。
上の図によると、
① 現在、%CPU 列に従ってソートされています。
② 上ボタンを使用して選択できます。および下キー
③ 右キーを押して列全体を選択し、次に上下キーを押して列全体の表示位置を移動し、前後に移動し、Enter を押して確定します。 ④ スペースバーを押して、またはを表示します
。列を非表示にします。表示したままにします。列を表示しない場合は表示されませ
ん。 ⑤ s キーを押します。 現在の列を並べ替え列として設定できます。
⑥ q キーを押して終了します。
3.2 最上位の共通パラメータ
トップコマンドの形式は次のとおりです。
top [选项]
----------------------------------
top命令常用的选项参数:
选项 功能
-d 指定每两次屏幕信息刷新之间的时间间隔,如希望每秒刷新一次,则使用:top -d 1
-p 通过指定PID来仅仅监控某个进程的状态
-S 指定累计模式
-s 使top命令在安全模式中运行。这将去除交互命令所带来的潜在危险
-i 使top不显示任何闲置或者僵死的进程
-c 显示整个命令行而不只是显示命令名
例えば:
每隔3秒显式所有进程的资源占用情况
top -d 1 每隔1秒显式所有进程的资源占用情况
top -c 每隔3秒显式进程的资源占用情况,并显示进程的命令行参数(默认只有进程名)
top -p 28820 -p 38830 每隔3秒显示pid是28820和pid是38830的两个进程的资源占用情况
top -d 2 -c -p 69358 每隔2秒显示pid是69358的进程的资源使用情况,并显式该进程启动的命令行参数
3.3 上位の対話型コマンド
デフォルトでは、top を入力すると、プロセスは CPU 使用率に従ってソートされます。
[1] 「top」と入力した後、キーボードの数字「1」を押して、各論理 CPU のステータスを監視します。
[2] 「top」と入力した後、「u」と入力し、次にユーザー名を入力すると、対応するユーザー プロセスが表示されます。
[3] 「top」と入力すると、top コマンドはデフォルトでメモリ サイズを K で表示します。大文字の E を使用してメモリ情報領域の表示単位を切り替えることができます。次のように、E を押すと MB に、E を押すとGB に切り替えます
:
【4】「top」と入力した後、「h」を入力してtopコマンドのヘルプドキュメントに入り、topの使い方の詳細を確認します。
もちろん、Top はシステムのステータスを確認するための最も一般的なコマンドです。他にも vmstat、w、uptime、iostat などのコマンドが多数あり、これらはすべて一般的に使用されるコマンドです。