IBM Cloud から提供されている 30 日間無料 Kubernetes サービス(IBM Kubernetes Service 、以下 "IKS")環境を使って利用することのできるコンテナイメージを1日に1個ずつ 30 日間連続で紹介していきます。
環境のセットアップや制約事項については Day0 のこちらの記事を参照してください。
Day 11 は Day 10 で紹介した MongoDB 環境を GUI で使うためのウェブツールから Mongo-Express イメージをデプロイする例を紹介します。
【イメージの概要】
Mongo-Express は MongoDB を CLI ではなく、GUI から利用するためのツール(ウェブ用クライアント)です。
【イメージのデプロイ】
まずはこちらのファイルを自分の PC にダウンロードしてください:
https://raw.githubusercontent.com/dotnsf/yamls_for_iks/main/mongoexpress.yaml
次にこのファイルをテキストエディタで開いてパラメータを編集します。具体的には以下2箇所の value 値を変更してください。それぞれの具体的な意味は以下の通りです:
・ME_CONFIG_MONGODB_SERVER : 接続先 MongoDB サーバー(初期値 xxx.xxx.xxx.xxx)
・ME_CONFIG_MONGODB_PORT : 接続先 MongoDB ポート番号(初期値 30017)
・ME_CONFIG_MONGODB_ENABLE_ADMIN : 接続先 MongoDB 管理者IDの自動設定(初期値 false ここはこのままで)
・ME_CONFIG_MONGODB_AUTH_USERNAME : 接続先 MongoDB 管理者ID(初期値 root)
・ME_CONFIG_MONGODB_AUTH_PASSWORD : 接続先 MongoDB 管理者パスワード(初期値 P@ssw0rd)
ではこのダウンロード&編集した mongoexpress.yaml ファイルを指定してデプロイします。以下のコマンドを実行する前に Day 0 の内容を参照して ibmcloud CLI ツールで IBM Cloud にログインし、クラスタに接続するまでを済ませておいてください。
そして以下のコマンドを実行します:
以下のコマンドで MongoDB および Mongo-Express 関連の Deployment, Service, Pod, Replicaset がそれぞれ1つずつ生成されたことと、サービスが 30017 番ポート(MongoDB)と 30080 番ポート(Mongo-Express)で公開されていることを確認します:
この後に実際にサービスを利用するため、以下のコマンドでワーカーノードのパブリック IP アドレスを確認します(以下の例であれば 161.51.204.190):
つまりこの時点で(上述の結果であれば)アプリケーションは http://169.51.204.190:30080/ で稼働している、ということになります。早速実行してみます。ウェブブラウザか curl コマンドを使って、アプリケーションの URL(上述の方法で確認した URL)にアクセスしてみます:
test データベースが存在しています。選択すると test データベースの内容を GUI で確認できます:
【YAML ファイルの解説】
YAML ファイルはこちらを使っています:
Deployment 1つと、Service 1つのごくごくシンプルな YAML ファイルですが、一応解説を加えておきます。アプリケーションそのものは 8081 番ポートで動作するように作られているため、NodePort 30080 番を指定して、外部からは 30080 番ポートでアクセスできるようにしています(NodePort として指定可能な番号の範囲は 30000 ~ 32767 です、指定しない場合は空いている番号がランダムに割り振られます)。また ReplicaSet は1つだけで作りました。
デプロイしたコンテナイメージを削除する場合はデプロイ時に使った YAML ファイルを再度使って、以下のコマンドを実行します。不要であれば削除しておきましょう(Day 10 の MongoDB も一緒に作成しておきましょう):
【紹介したイメージ】
https://hub.docker.com/_/mongo-express
【紹介記録】
環境のセットアップや制約事項については Day0 のこちらの記事を参照してください。
Day 11 は Day 10 で紹介した MongoDB 環境を GUI で使うためのウェブツールから Mongo-Express イメージをデプロイする例を紹介します。
【イメージの概要】
Mongo-Express は MongoDB を CLI ではなく、GUI から利用するためのツール(ウェブ用クライアント)です。
【イメージのデプロイ】
まずはこちらのファイルを自分の PC にダウンロードしてください:
https://raw.githubusercontent.com/dotnsf/yamls_for_iks/main/mongoexpress.yaml
次にこのファイルをテキストエディタで開いてパラメータを編集します。具体的には以下2箇所の value 値を変更してください。それぞれの具体的な意味は以下の通りです:
・ME_CONFIG_MONGODB_SERVER : 接続先 MongoDB サーバー(初期値 xxx.xxx.xxx.xxx)
・ME_CONFIG_MONGODB_PORT : 接続先 MongoDB ポート番号(初期値 30017)
・ME_CONFIG_MONGODB_ENABLE_ADMIN : 接続先 MongoDB 管理者IDの自動設定(初期値 false ここはこのままで)
・ME_CONFIG_MONGODB_AUTH_USERNAME : 接続先 MongoDB 管理者ID(初期値 root)
・ME_CONFIG_MONGODB_AUTH_PASSWORD : 接続先 MongoDB 管理者パスワード(初期値 P@ssw0rd)
ではこのダウンロード&編集した mongoexpress.yaml ファイルを指定してデプロイします。以下のコマンドを実行する前に Day 0 の内容を参照して ibmcloud CLI ツールで IBM Cloud にログインし、クラスタに接続するまでを済ませておいてください。
そして以下のコマンドを実行します:
$ kubectl apply -f mongoexpress.yaml
以下のコマンドで MongoDB および Mongo-Express 関連の Deployment, Service, Pod, Replicaset がそれぞれ1つずつ生成されたことと、サービスが 30017 番ポート(MongoDB)と 30080 番ポート(Mongo-Express)で公開されていることを確認します:
$ kubectl get all NAME READY STATUS RESTARTS AGE pod/mongo-65cb95c444-xkgx9 1/1 Running 0 5m43s pod/mongo-express-65fc46bf78-vprjb 1/1 Running 0 18s NAME TYPE CLUSTER-IP EXTERNAL-IP PORT(S) AGE service/kubernetes ClusterIP 172.21.0.1 <none> 443/TCP 27d service/mongo-express NodePort 172.21.156.220 <none> 8081:30080/TCP 19s service/mongoserver NodePort 172.21.93.229 <none> 27017:30017/TCP 5m45s NAME READY UP-TO-DATE AVAILABLE AGE deployment.apps/mongo 1/1 1 1 5m44s deployment.apps/mongo-express 1/1 1 1 19s NAME DESIRED CURRENT READY AGE replicaset.apps/mongo-65cb95c444 1 1 1 5m44s replicaset.apps/mongo-express-65fc46bf78 1 1 1 19s
この後に実際にサービスを利用するため、以下のコマンドでワーカーノードのパブリック IP アドレスを確認します(以下の例であれば 161.51.204.190):
$ ibmcloud ks worker ls --cluster=mycluster-free
OK
ID パブリック IP プライベート IP フレーバー 状態 状況 ゾーン バージョン
kube-c3biujbf074rs3rl76t0-myclusterfr-default-000000df 169.51.204.190 10.144.185.144 free normal Ready mil01 1.20.7_1543*
つまりこの時点で(上述の結果であれば)アプリケーションは http://169.51.204.190:30080/ で稼働している、ということになります。早速実行してみます。ウェブブラウザか curl コマンドを使って、アプリケーションの URL(上述の方法で確認した URL)にアクセスしてみます:
test データベースが存在しています。選択すると test データベースの内容を GUI で確認できます:
【YAML ファイルの解説】
YAML ファイルはこちらを使っています:
apiVersion: v1 kind: Service metadata: name: mongo-express spec: selector: app: mongo-express ports: - port: 8081 protocol: TCP targetPort: 8081 nodePort: 30080 type: NodePort --- apiVersion: apps/v1 kind: Deployment metadata: name: mongo-express spec: replicas: 1 selector: matchLabels: app: mongo-express template: metadata: labels: app: mongo-express spec: containers: - name: mongo-express image: mongo-express env: - name: ME_CONFIG_MONGODB_SERVER value: "xxx.xxx.xxx.xxx" - name: ME_CONFIG_MONGODB_PORT value: "30017" - name: ME_CONFIG_MONGODB_ENABLE_ADMIN value: "false" - name: ME_CONFIG_MONGODB_AUTH_USERNAME value: "root" - name: ME_CONFIG_MONGODB_AUTH_PASSWORD value: "Passw0rd" ports: - containerPort: 8081
Deployment 1つと、Service 1つのごくごくシンプルな YAML ファイルですが、一応解説を加えておきます。アプリケーションそのものは 8081 番ポートで動作するように作られているため、NodePort 30080 番を指定して、外部からは 30080 番ポートでアクセスできるようにしています(NodePort として指定可能な番号の範囲は 30000 ~ 32767 です、指定しない場合は空いている番号がランダムに割り振られます)。また ReplicaSet は1つだけで作りました。
デプロイしたコンテナイメージを削除する場合はデプロイ時に使った YAML ファイルを再度使って、以下のコマンドを実行します。不要であれば削除しておきましょう(Day 10 の MongoDB も一緒に作成しておきましょう):
$ kubectl delete -f mongoexpress.yaml
【紹介したイメージ】
https://hub.docker.com/_/mongo-express
【紹介記録】
Day | カテゴリー | デプロイ内容 |
---|---|---|
0 | 準備 | 準備作業 |
1 | ウェブサーバー | hostname |
2 | Apache HTTP | |
3 | Nginx | |
4 | Tomcat | |
5 | Websphere Liberty | |
6 | データベース | MySQL |
7 | phpMyAdmin | |
8 | PostgreSQL | |
9 | pgAdmin4 | |
10 | MongoDB | |
11 | Mongo-Express | |
12 | Redis | |
13 | RedisCommander | |
14 | ElasticSearch | |
15 | Kibana | |
16 | CouchDB | |
17 | CouchBase | |
18 | HATOYA | |
19 | プログラミング | Node-RED |
20 | Scratch | |
21 | Eclipse Orion | |
22 | Swagger Editor | |
23 | R Studio | |
24 | Jenkins | |
25 | アプリケーション | FX |
26 | 2048 | |
27 | DOS Box | |
28 | VNC Server(Lubuntu) | |
29 | Drupal | |
30 | WordPress |
コメント