リソース制御でサービスレベルを確保せよ実践! Xenで実現するサーバ統合(5)(2/3 ページ)

» 2008年03月18日 00時00分 公開
[中嶋一樹, 高橋浩和住商情報システム株式会社/VA Linux Systems Japan株式会社]

CPUのリソース制御(2)

■CPU利用率閾値

 仮想CPUの利用率の上限値です。例えば大きなプログラムのソースコードをコンパイルすると、通常、CPU利用率は100%に近い値に張り付きます。その際、この閾値を50に設定しておくと、どれだけCPUリソースを要求しても50%までしかリソースが割り当てられないということになります。

コラム●steal値で把握できるCPUリソースの状況

 この状態は、vmstatコマンドを使えば容易に確認できます。usr列、sys列の値が合計で50%までしか上昇せず、代わりにsteal列に残りの50%近い値が表示されると思います。 

 steal列には、ゲストOSがリソース要求を行ったにもかかわらずCPUリソースを割り当ててもらえなかった時間の割合が表示されます。steal列に0%以外の値が表示されている場合はCPU利用率閾値設定が行われているか、ほかのゲストOSあるいはホストOSが同時にCPUリソースを要求して「取り合い」の状態になっていることが考えられます。

 特に閾値を設定していないにもかかわらずこのstealの値が高いようであれば、そのホストサーバは全体として過負荷になっているか、前述のCPUマッピング設定がアンバランスになっている可能性が高いと判断できます。


 ただしこの設定値の範囲は、0?(100×仮想CPU数)となります。例えば仮想CPUを2個割り当てている際にCPU利用率を50%に制限したい場合は、100と設定する必要があります。0とした場合には上限なしと解釈されます。稼働中にも動的に変更可能です。

設定ファイルでの書式
なし

xmコマンドでの書式
# xm sched-credit -dドメイン名 -c 閾値
   #-c 0は閾値なし(デフォルト)となる

確認方法
# xm sched-credit -d ドメイン名
{'cap': 0, 'weight': 256}
# 'cap'の値が閾値

■CPUスケジュール優先度

 全体としてCPUリソース利用状況が混雑してきたときにゲストOSがリソースを獲得できる優先度を設定します。

 この値は、利用率閾値設定と違って、絶対的な上限値を定めるものではありません。あくまでもCPUリソース取得要求がほかのゲストOSとかち合った場合にどれだけ優先してこのゲストOSがリソースを割り当てられるかという設定値になります。設定値は1〜65535となっており、デフォルトは256です。稼働中にも動的に変更可能です。

設定ファイルでの書式
なし

xmコマンドでの書式
# xm sched-credit -dドメイン名 -w 閾値

確認方法
# xm sched-credit -d ドメイン名
{'cap': 0, 'weight': 256}
  # 'weight'の値が閾値

メモリのリソース制御

■メモリ割り当て量/最大値

 ゲストOSに割り当てるメモリ量とその最大値です。稼働中でも動的に変更可能です。

 ただし、最大値の設定には注意が必要です。RHEL5の現在のXenでは、メモリの最大値を設定するxm mem-maxというコマンドオプションがあります。このコマンドは仕様上、もともと設定されていた最大値よりも低い値を設定するときに有効に作用する仕組みになっているはずですが、xm list --longという設定値を確認するコマンドの出力結果が期待値と異なっていたり、エラーを出すべき値を設定してもエラーとならなかったりと、混乱させる動作になっています。

 ですので現在のところ、最大値については常に設定ファイルで指定するようにし、xm mem-maxコマンドオプションは使用しないことをお勧めします。さらに、ゲストOSにこの設定ファイルを読み込ませる際には、リブートではなくシャットダウンが必要になることにも注意が必要です。リブートしただけでは設定変更が反映されません。

設定ファイルでの書式
memory = 割り当て量
maxmem = 最大値

xmコマンドでの書式
# xm mem-setドメイン名 割り当て量(メガバイト単位)

確認方法
# xm list --longドメイン名
(domain
    (domid 14)
    (uuid c2fd0de9-43b8-4e52-9b6e-cd626e15f972)
    (vcpus 1)
    (cpu_weight 1.0)
    (memory 512)
    (shadow_memory 0)
    (maxmem 1024)
以下省略

Copyright © ITmedia, Inc. All Rights Reserved.

スポンサーからのお知らせPR

注目のテーマ

AI for エンジニアリング
「サプライチェーン攻撃」対策
1P情シスのための脆弱性管理/対策の現実解
OSSのサプライチェーン管理、取るべきアクションとは
Microsoft & Windows最前線2024
システム開発ノウハウ 【発注ナビ】PR
あなたにおすすめの記事PR

RSSについて

アイティメディアIDについて

メールマガジン登録

@ITのメールマガジンは、 もちろん、すべて無料です。ぜひメールマガジンをご購読ください。