前回は、
Worker Nodeの種類 ─Public Worker NodeとPrivate Worker Node
DCOSで実際にアプリケーションを動作させるノードをWorker Nodeと呼び、
Private Worker Nodeは内部ネットワークのIPアドレスだけが割り当てられ、
Public Worker Node、
data:image/s3,"s3://crabby-images/ba308/ba308246f8e5fcaf668cf66f8719424f608c6c06" 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/04ea1/04ea12d513c4bf66064fe400aa9695ffe917d081" alt="画像"
“marathon”
data:image/s3,"s3://crabby-images/4b42c/4b42c9b0df68993995e74b280997d4467134db69" alt="画像"
DCOS GUIのURLを”
data:image/s3,"s3://crabby-images/a68d3/a68d362c6dd038b12a85d66c191d4d4ec0f55df2" alt="画像"
各ジョブの右側の”
data:image/s3,"s3://crabby-images/b178f/b178fdddacdfb0a2821e73aa12641ab5d47249a2" alt="画像"
data:image/s3,"s3://crabby-images/00e96/00e969e68bfcc5d99507bc35f12327fa5ee38d2c" alt="標準出力の例 標準出力の例"
data:image/s3,"s3://crabby-images/00cb4/00cb4b3060d96f47faf4d353321a719fda7c3909" 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/321f6/321f67ef16d98861d91546eba65bc0068b99cda1" alt="画像"
AWS-CloudFoundation管理コンソールの[Output]タブを選択し、”
成功すると、
data:image/s3,"s3://crabby-images/f0a0c/f0a0c3fd76322b00464ac038c33b555eb8d5c3b5" alt="画像"
アプリケーションを終了するにはDCOS CLIから以下のようにコマンドを実行します
$ dcos marathon app remove /webgl-earth
さいごに
DCOSを使うことで、
現在DCOS Community EditionはAWS上での動作に限られていますが、
弊社ではDCOSの普及及び具体的な事例に即したコンサルテーションを行っています。ご興味がありましたらぜひ sales@creationline.