2022年4月4日月曜日

k3sでNode-Redを配備する

Node-Redを使用してフロー図によるプログラム開発を行うことができます。k3sでNode-Redを配備するには、以下の手順を実行します。データはlocal永続ボリュームに保存します。

実行手順

1. local永続ボリュームで使用するディレクトリの作成
以下のコマンドでlocal永続ボリュームで使用するディレクトリを作成します。
sudo mkdir -p /var/nodered-data

sudo chown 1000:1000 /var/nodered-data

2. local永続ボリュームの作成
以下のコマンドでlocal永続ボリュームを作成します。
cat << EOF > local-nodered-pv.yml
apiVersion: v1
kind: PersistentVolume
metadata:
  name: local-nodered-pv
spec:
  capacity:
    storage: 5Gi
  accessModes:
  - ReadWriteOnce
  storageClassName: local-storage
  local:
    path: /var/nodered-data
  nodeAffinity:
    required:
      nodeSelectorTerms:
      - matchExpressions:
        - key: kubernetes.io/hostname
          operator: In
          values:
          - `hostname`
EOF
※`hostname`は今ログオンしているk3sがインストールされているホスト名になります。適宜変更してください。
sudo k3s kubectl apply -f ./local-nodered-pv.yml

3. 永続ボリューム要求の作成
以下のコマンドで永続ボリューム要求を作成します。
cat << EOF > local-nodered-pvc.yml
apiVersion: v1
kind: PersistentVolumeClaim
metadata:
  name: local-nodered-pvc
spec:
  accessModes:
    - ReadWriteOnce
  storageClassName: local-storage
  resources:
    requests:
      storage: 5Gi
  volumeName: local-nodered-pv
EOF

sudo k3s kubectl apply -f ./local-nodered-pvc.yml

4. Node-REDのDeploymentの作成
以下のコマンドでNode-REDのDeploymentを作成します。
cat << EOF > nodered-deployment.yml
apiVersion: apps/v1
kind: Deployment
metadata:
  name: nodered-deployment
  labels:
    app: nodered
spec:
  replicas: 1
  selector:
    matchLabels:
      app: nodered
  strategy:
    type: Recreate
  template:
    metadata:
      labels:
        app: nodered
    spec:
      containers:
      - name: nodered
        image: nodered/node-red:latest
        env:
        - name: TZ
          value: Asia/Tokyo
        ports:
        - containerPort: 1880
        volumeMounts:
        - name: nodered-data
          mountPath: /data
      volumes:
      - name: nodered-data
        persistentVolumeClaim:
          claimName: local-nodered-pvc
EOF

sudo k3s kubectl apply -f ./nodered-deployment.yml

5. サービスの作成
以下のコマンドでサービスを作成します。
cat << EOF > nodered-service.yml
apiVersion: v1
kind: Service
metadata:
  name: nodered-service
spec:
  selector:
    app: nodered
  type: LoadBalancer
  externalIPs:
  - xxx.xxx.xxx.xxx # 外部からアクセスできるk3sをインストールしたホストのIPを設定します。
  ports:
  - name: http
    protocol: TCP
    port: 8080
    targetPort: 1880
EOF

sudo k3s kubectl apply -f ./nodered-service.yml

ブラウザからhttp://<ホスト名またはIP:8080>/ にアクセスします。

0 件のコメント:

コメントを投稿