Geard のポートマッピングについて調べてみた

こんにちは。@jedipunkz です。

今週 Redhat が ‘Redhat Enterprise Linux Atomic Host’ しましたよね。Docker を特 徴としたミニマムな OS だとのこと。その内部で用いられている技術 Geard について 少し調べてみました。複数コンテナの関連付けが可能なようです。ここでは調べた結果 について簡単にまとめていきます。

参考資料

http://openshift.github.io/geard/deploy_with_geard.html

利用方法

ここではホスト OS に Fedora20 を用意します。

まず Geard をインストール

% sudo yum install --enablerepo=updates-testing geard

下記の json ファイルを作成します。ここにはコンテナをデプロイするための情報と関 連付けのための情報を記します。

$ ${EDITOR} rockmongo_mongodb.json
{
  "containers":[
    {
      "name":"rockmongo",
      "count":1,
      "image":"derekwaynecarr/rockmongo",
      "publicports":[{"internal":80,"external":6060}],
      "links":[{"to":"mongodb"}]
    },
    {
      "name":"mongodb",
      "count":1,
      "image":"ccoleman/ubuntu-mongodb",
      "publicports":[{"internal":27017}]
    }
  ]
}

上記のファイルの解説。

  • コンテナ ‘rockmongo’ と ‘mongodb’ を作成
  • それぞれ1個ずつコンテナを作成
  • ‘image’ パラメータにて docker イメージの指定
  • ‘publicports’ パラメータにてコンテナ内部とホスト側のポートマッピングを行う
  • ‘links’ パラメータで ‘rockmongo’ を ‘mongodb’ に関連付け

では、デプロイ開始します。

$ sudo gear deploy rockmongo_mongo.json
2014/04/22 07:21:12 Deploying rockmongo_mongo.json.20140422-072112
2014/04/22 07:21:12 appending 27017 on rockmongo-1: &{PortPair:{Internal:27017 External:0} Target:127.0.0.1:27017} &{Id:rockmongo-1 Image:derekwaynecarr/rockmongo From:rockmongo On:0xc2100bb980 Ports:[{PortPair:{Internal:80 External:6060} Target::0}] add:true remove:false container:0xc21000be00 links:[]}
2014/04/22 07:21:12 ports: Releasing
2014/04/22 07:21:12 systemd: Reloading daemon
local PortMapping: 80 -> 6060
local Container rockmongo-1 is installed
2014/04/22 07:21:12 ports: Releasing
2014/04/22 07:21:12 systemd: Reloading daemon
local PortMapping: 27017 -> 4000
local Container mongodb-1 is installed
linking rockmongo: 127.0.0.1:27017 -> localhost:4000
local Links set on local
local Container rockmongo-1 starting
local Container mongodb-1 starting

ブラウザにてホスト OS に接続することで rockmongo の管理画面にアクセスが可能。

http://<ホストOSのIP:6060>/

ポートマッピング管理

デプロイが完了して、実際に RockMongo の管理画面にアクセス出来たと思います。 関連付けが特徴と言えそうなのでその解析をしてみました。

Geard のコンテナ関連付けはホストとコンテナのポート管理がキモとなっていることが 解ります。これを紐解くことで geard のコンテナ管理を理解します。

                        'rockmongo' コンテナ             'mongodb' コンテナ
+----------+        +--------------------------+        +-------------------+
|  Client  |->6060->|->80-> RockMongo ->27017->|->4000->|->27017-> Mongodb  |
+----------+        +--------------------------+        +-------------------+
                    |-------------------- docker ホスト --------------------|

上記 ‘gear deploy’ コマンド発行時のログと json ファイルにより上図のような構成 になっていることが理解できます。一つずつ読み解いていきましょう。

  • ‘rockmongo’ コンテナの内部でリスンしている 80 番ポートはホスト OS の 6060 番へ変換
  • ‘rockmongo’ コンテナ内で稼働する RockMongo の config.php から ‘127.0.0.1:27017’ でリスンしていることが解る

試しに ‘derekwaynecarr/rockmongo:latest’ に /bin/bash でログインし config.php を確認。

$ sudo docker run -i -t derekwaynecarr/rockmongo:latest /bin/bash
bash-4.1# grep mongo_host /var/www/html/config.php
$MONGO["servers"][$i]["mongo_host"] = "127.0.0.1";//mongo host
$MONGO["servers"][$i]["mongo_host"] = "127.0.0.1";
  • デプロイ時のログと json ファイルの ‘links’ パラメータより、ホストのポートに動的に(ここでは 4000番ポート) に変換されることが解ります。

    linking rockmongo: 127.0.0.1:27017 -> localhost:4000
  • ホストの 4000 番ポートは動的に ‘mongodb’ コンテナの内部ポート 27017 にマッピングされる

これらのポートマッピングによりそれぞれのコンテナの連携が取れている。

まとめと考察

Geard は下記の2つを特徴とした技術だと言えるとことがわかりました。

  • コンテナを json で管理しデプロイする仕組みを提供する
  • コンテナ間の関連付けをホスト OS のポートを動的に管理・マッピングすることで行う

同じような OS に CoreOS https://coreos.com/ がありますが、こちらも docker, sytemd 等を特徴としています。さらに etcd を使ってクラスタの構成等が可能になっ ていますが、Geard はホストのポートを動的に管理することで関連付けが可能なことが わかりました。

実際に触ってみた感覚から言えば、まだまだ実用化は厳しい状況に思えますが、今後へ の展開に期待したい技術です。