IBM Cloud から提供されている 30 日間無料 Kubernetes サービスIBM Kubernetes Service 、以下 "IKS")環境を使って利用することのできるコンテナイメージを1日に1個ずつ 30 日間連続で紹介していきます。

環境のセットアップや制約事項については Day0 のこちらの記事を参照してください。

Day 11 は Day 10 で紹介した MongoDB 環境を GUI で使うためのウェブツールから Mongo-Express イメージをデプロイする例を紹介します。
mongoexpress1



【イメージの概要】
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)にアクセスしてみます:
mongoexpress1


test データベースが存在しています。選択すると test データベースの内容を GUI で確認できます:
mongoexpress2



【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
2Apache HTTP
3Nginx
4Tomcat
5Websphere Liberty
6データベースMySQL
7phpMyAdmin
8PostgreSQL
9pgAdmin4
10MongoDB
11Mongo-Express
12Redis
13RedisCommander
14ElasticSearch
15Kibana
16CouchDB
17CouchBase
18HATOYA
19プログラミングNode-RED
20Scratch
21Eclipse Orion
22Swagger Editor
23R Studio
24Jenkins
25アプリケーションFX
262048
27DOS Box
28VNC Server(Lubuntu)
29Drupal
30WordPress