実行手順
1. local永続ボリュームで使用するディレクトリの作成以下のコマンドでlocal永続ボリュームで使用するディレクトリを作成します。
minikube ssh
sudo mkdir -p /var/mysql-data
sudo mkdir -p /var/n8n-data
exit
2. local永続ボリュームの作成
以下のコマンドでlocal永続ボリュームを作成します。
※MySQLデータ用
cat << EOF > local-mysql-pv.yml
apiVersion: v1
kind: PersistentVolume
metadata:
name: local-mysql-pv
spec:
capacity:
storage: 5Gi
accessModes:
- ReadWriteOnce
storageClassName: local-storage
local:
path: /var/mysql-data
nodeAffinity:
required:
nodeSelectorTerms:
- matchExpressions:
- key: kubernetes.io/hostname
operator: In
values:
- minikube
EOF
kubectl apply -f ./local-mysql-pv.yml
※n8n.io用
cat << EOF > local-n8n-pv.yml
apiVersion: v1
kind: PersistentVolume
metadata:
name: local-n8n-pv
spec:
capacity:
storage: 5Gi
accessModes:
- ReadWriteOnce
storageClassName: local-storage
local:
path: /var/n8n-data
nodeAffinity:
required:
nodeSelectorTerms:
- matchExpressions:
- key: kubernetes.io/hostname
operator: In
values:
- minikube
EOF
kubectl apply -f ./local-n8n-pv.yml
3. 永続ボリューム要求の作成
以下のコマンドで永続ボリューム要求を作成します。
※MySQLDBデータ用
cat << EOF > local-mysql-pvc.yml
apiVersion: v1
kind: PersistentVolumeClaim
metadata:
name: local-mysql-pvc
spec:
accessModes:
- ReadWriteOnce
storageClassName: local-storage
resources:
requests:
storage: 5Gi
volumeName: local-mysql-pv
EOF
kubectl apply -f ./local-mysql-pvc.yml
※n8n.io用
cat << EOF > local-n8n-pvc.yml
apiVersion: v1
kind: PersistentVolumeClaim
metadata:
name: local-n8n-pvc
spec:
accessModes:
- ReadWriteOnce
storageClassName: local-storage
resources:
requests:
storage: 5Gi
volumeName: local-n8n-pv
EOF
kubectl apply -f ./local-n8n-pvc.yml
4. n8n.ioとMySQLのDeploymentの作成
以下のコマンドでn8n.ioとMySQLを含むポッドと作成したlocal永続ボリュームを使用するDeploymentを作成します。
cat << EOF > n8n-mysql-deployment.yml
apiVersion: apps/v1
kind: Deployment
metadata:
name: n8n-mysql-deployment
labels:
app: n8n-mysql
spec:
replicas: 1
selector:
matchLabels:
app: n8n-mysql
strategy:
type: Recreate
template:
metadata:
labels:
app: n8n-mysql
spec:
containers:
- name: mysql
image: mysql:5.7
env:
- name: MYSQL_ROOT_PASSWORD
value: n8n
- name: MYSQL_DATABASE
value: n8n
- name: MYSQL_USER
value: n8n
- name: MYSQL_PASSWORD
value: n8n
ports:
- containerPort: 3306
volumeMounts:
- name: mysql-data
mountPath: /var/lib/mysql
- name: n8n
image: n8nio/n8n
env:
- name: DB_TYPE
value: mysqldb
- name: MYSQLDB_DATABASE
value: n8n
- name: DB_MYSQLDB_HOST
value: 127.0.0.1
- name: DB_MYSQLDB_PORT
value: "3306"
- name: DB_MYSQLDB_USER
value: n8n
- name: DB_MYSQLDB_PASSWORD
value: n8n
- name: GENERIC_TIMEZONE
value: Asia/Tokyo
- name: TZ
value: Asia/Tokyo
ports:
- containerPort: 5678
volumeMounts:
- name: n8n-data
mountPath: /home/node/.n8n
dnsConfig:
options:
- name: ndots
value: "1"
volumes:
- name: mysql-data
persistentVolumeClaim:
claimName: local-mysql-pvc
- name: n8n-data
persistentVolumeClaim:
claimName: local-n8n-pvc
EOF
kubectl apply -f ./n8n-mysql-deployment.yml
5. サービスの作成
以下のコマンドでサービスを作成します。
cat << EOF > n8n-service.yml
apiVersion: v1
kind: Service
metadata:
name: n8n-service
spec:
selector:
app: n8n-mysql
ports:
- name: http
protocol: TCP
port: 8080
targetPort: 5678
- name: db
protocol: TCP
port: 3306
targetPort: 3306
EOF
kubectl apply -f ./n8n-service.yml
6. Port-Fowardingで外部からアクセスできるようにする
kubectl port-forward --address 0.0.0.0 service/n8n-service 8080:8080 3306:3306
ブラウザからhttp://<ホスト名:8080/ にアクセスしてワークフローを作成します。
0 件のコメント:
コメントを投稿