前回は、
Worker Nodeの種類 ─Public Worker NodeとPrivate Worker Node
DCOSで実際にアプリケーションを動作させるノードをWorker Nodeと呼び、
Private Worker Nodeは内部ネットワークのIPアドレスだけが割り当てられ、
Public Worker Node、
data:image/s3,"s3://crabby-images/2430b/2430b4a06f8cc55c39475b600deb530d0915251d" alt="画像"
通常DCOSでアプリケーションの動作を開始すると、
しかし、
また、
アプリケーションの実行方法
DCOSでのアプリケーション実行方法は大きく分けて2種類あります。
- DCOSアプリケーションリポジトリにあるアプリケーションの実行
- 独自アプリケーションの実行
DCOSアプリケーションリポジトリにあるアプリケーションの実行は非常に簡単で、”
DCOSアプリケーションリポジトリにない独自アプリケーションも、
DCOSアプリケーションリポジトリ
DCOSの大きな特長の1つが、
- Marathon
- Chronos
- Apache Spark
- Apache Kafka
- Kubernetes
- HDFS
- Apache Cassandra
アプリケーションリポジトリ自体はGitHub上でメンテナンスされており、
- ※)
- DCOSのリファレンスページで現在利用可能なアプリケーションと、
計画中のアプリケーションの一覧を見ることができます。
アプリケーション例① Apache Spark
1つめの例がApache Sparkです。Apache SparkはDCOSアプリケーションリポジトリに登録されているアプリケーションで、
$ dcos package install spark
同様にDCOSアプリケーションリポジトリに登録されているアプリケーションは、”
アプリケーション例② スクリプト
次に簡単なPythonスクリプトを動作させてみましょう。DCOSのWorker NodeにはPython3が標準で入っていますので、
以下が実際に動作させるPythonスクリプトです。10秒sleepして経過時間を標準出力に書き出します。
#!/usr/bin/env python3
import time
start = time.time()
time.sleep(10)
end = time.time()
elapsed = end - start
print("elapsed: ", elapsed)
DCOSはWorker Nodeへのデータの受け渡しにhttpを使います。今回は上記のスクリプトをgistに置き、
最後にDCOSにジョブとして投入するためのJSON定義ファイルを作成します。
{
"id": "python-sleep",
"cmd": "chmod u+x test.py && ./test.py",
"cpus": 0.1,
"mem": 10.0,
"instances": 1,
"uris": [ "https://gist.githubusercontent.com/mkiuchi/b59989d37f65b1823994/raw/41412a57384a9ed6adb35800c5aa483419e67e41/test.py"
]
}
最後にdcosコマンドでDCOSクラスタにジョブとして投入します
$ dcos marathon app add python-sleep.json
DCOS GUIの左側の[Services]を選択すると、
data:image/s3,"s3://crabby-images/7bbf0/7bbf0e21469524bcb62b2d1158a5a15936ace84f" alt="画像"
“marathon”
data:image/s3,"s3://crabby-images/a9b8a/a9b8a53202d10edd3c6cec0d124f2d7ba31b82d2" alt="画像"
DCOS GUIのURLを”
data:image/s3,"s3://crabby-images/43f6d/43f6d4d6a01599455a50bd436217f7082b057598" alt="画像"
各ジョブの右側の”
data:image/s3,"s3://crabby-images/88541/88541deb13084b0c6e3dde13381ed924c6c772c1" alt="画像"
data:image/s3,"s3://crabby-images/890b9/890b9e8ea4a83f028241adb099dbcbb2d45bd1e3" alt="標準出力の例 標準出力の例"
data:image/s3,"s3://crabby-images/72834/728340bc43d2f80840fa8c9e287cca23db9c8300" alt="標準エラー出力の例 標準エラー出力の例"
marathonはスクリプトが終了すると自動的に起動しなおすため、
$ dcos marathon app remove /python-sleep
アプリケーション例③ Dockerコンテナと連携したアプリケーション
DCOSはDockerと連携することで、
以下のファイルが、
{
"container": {
"type": "DOCKER",
"docker": {
"network": "BRIDGE",
"portMappings": [
{ "containerPort": 80, "hostPort": 80 }
],
"image": "mkiuchi/webglearth"
}
},
"acceptedResourceRoles": ["slave_public"],
"ports": [80],
"requirePorts": true,
"id": "webgl-earth",
"cpus": 0.01,
"mem": 256
}
DCOS CLIからこのJSONファイルを使ってジョブを投入します。
$ dcos marathon app add webgl-earth.json
1~2分ほど待ってからMarathonの管理インターフェイスを見ると、
data:image/s3,"s3://crabby-images/bfbfd/bfbfde75cd423f12fe9f77528a9d36723345d589" alt="画像"
AWS-CloudFoundation管理コンソールの[Output]タブを選択し、”
成功すると、
data:image/s3,"s3://crabby-images/d5486/d5486bec1b811b457532462301dd26993a9a08df" alt="画像"
アプリケーションを終了するにはDCOS CLIから以下のようにコマンドを実行します
$ dcos marathon app remove /webgl-earth
さいごに
DCOSを使うことで、
現在DCOS Community EditionはAWS上での動作に限られていますが、
弊社ではDCOSの普及及び具体的な事例に即したコンサルテーションを行っています。ご興味がありましたらぜひ sales@creationline.