Qiita Teams that are logged in
You are not logged in to any team

Log in to Qiita Team
Community
OrganizationAdvent CalendarQiitadon (β)
Service
Qiita JobsQiita ZineQiita Blog
Help us understand the problem. What is going on with this article?

dockerコンテナ リソース変化とメトリクス確認(docker stats, htop)

More than 1 year has passed since last update.

Dockerのリソース変化

dockerを0から触れていまだ勉強中なので記事内に間違った内容などがあれば編集リクエストを送っていただけるととても助かります:bow:

cpu割り当て時間

dockerコンテナのcpu割り当て時間は基本的に100%で割り振られ,そのコアに割り当てられたコンテナの個数で決まる. なので1つだけコンテナを立てるとcpuの割り当て時間は100%になってしまう.
要するに同じコアに3つコンテナが建てられたら1つあたりの割り当て時間は、100/3で33.333...%になるらしい.

cpuのコアの指定には--cpuset-cpus
cpu割り当て時間の変更には--cpusを使い変更.
以下の例は起動中のコンテナのcpuコアを1にして割り当て時間を50%にする場合です.

docker container update --cpuset-cpus=0 --cpus="0.5" <変更したいコンテナID>

メモリ割り当て

メモリの割り当て変更には, -mを使います.
以下の例は, 起動中のコンテナのメモリ容量を100MBに制限する例です.

docker container update -m 100m <変更したいコンテナID>

制限したいメモリ容量の単位は、b(バイト)k(キロバイト)m(メガバイト)g(ギガバイト)が使えます.

コンテナメトリクス

コンテナのメトリクスを確認するうえで手っ取り早いのは
- docker stats
- htop
個人的には、この2つだと思います...
(コンテナのメトリクス確認なのでデータ取得にはdata dogやelasticsaerchを入れたほうが楽)

docker stats

docker statsを実行するだけで起動中のコンテナの状態を一目で確認することができます.

docker stats
CONTAINER ID        NAME                CPU %               MEM USAGE / LIMIT   MEM %               NET I/O             BLOCK I/O           PIDS
e7c6f7cd0153        magical_elbakyan    9.84%               50.67MiB / 100MiB   50.67%              9.97kB / 0B         341MB / 807MB       1
7d8cddfc7d9c        nervous_jones       50.08%              52.11MiB / 100MiB   52.11%              9.97kB / 0B         8.24GB / 8.91GB     1
d7d25131fa19        confident_kilby     100.33%             53.11MiB / 100MiB   53.11%              10.2kB / 0B         3.87TB / 10.7TB     1
docker stats 意味
cpu% cpu割り当て時間
MEM use メモリ使用量
MEM% メモリ使用率
NET I/O ネットワークI/O
BLOCK I/O 入出力中の待機I/O

htop

htopはdocker statsとは違い実行したマシンのプロセスがすべて表示されます.
htopで実行
キャプチャ.PNG

cpuの状態とメモリ, swap, load averageが一目で見れてCPU・メモリ使用量で並び変えもできるので マシン全体でコンテナがどう動いているかの確認に向いてると思います.

htopステータス 意味
PID プロセスID
NI プロセス優先度
VIRT 仮想メモリ
RES 物理メモリ
SHR プロセスと共有されるメモリ
S プロセス起動状態
CPU% cpu使用率
MEM% メモリ使用率
TIME+ プロセス起動時間

参考文献

この記事は以下の情報を参考にして執筆しました。

cdsl
東京工科大学コンピュータサイエンス学部クラウド・分散システム研究室
https://www.tak-cslab.org/
Why not register and get more from Qiita?
  1. We will deliver articles that match you
    By following users and tags, you can catch up information on technical fields that you are interested in as a whole
  2. you can read useful information later efficiently
    By "stocking" the articles you like, you can search right away