実行手順
1. local永続ボリュームで使用するディレクトリの作成以下のコマンドでlocal永続ボリュームで使用するディレクトリを作成します。
minikube ssh
sudo mkdir -p /var/pgdata
sudo mkdir -p /var/metabase
exit
2. local永続ボリュームの作成
以下のコマンドでlocal永続ボリュームを作成します。
※PostgreSQLデータ用
cat << EOF > local-pg-pv.yml
apiVersion: v1
kind: PersistentVolume
metadata:
name: local-pg-pv
spec:
capacity:
storage: 5Gi
accessModes:
- ReadWriteOnce
storageClassName: local-storage
local:
path: /var/pgdata
nodeAffinity:
required:
nodeSelectorTerms:
- matchExpressions:
- key: kubernetes.io/hostname
operator: In
values:
- minikube
EOF
kubectl apply -f ./local-pg-pv.yml
※Metabase用
cat << EOF > local-metabase-pv.yml
apiVersion: v1
kind: PersistentVolume
metadata:
name: local-metabase-pv
spec:
capacity:
storage: 5Gi
accessModes:
- ReadWriteOnce
storageClassName: local-storage
local:
path: /var/metabase
nodeAffinity:
required:
nodeSelectorTerms:
- matchExpressions:
- key: kubernetes.io/hostname
operator: In
values:
- minikube
EOF
kubectl apply -f ./local-metabase-pv.yml
3. 永続ボリューム要求の作成
以下のコマンドで永続ボリューム要求を作成します。
※PostgreSQL用
cat << EOF > local-pg-pvc.yml
apiVersion: v1
kind: PersistentVolumeClaim
metadata:
name: local-pg-pvc
spec:
accessModes:
- ReadWriteOnce
storageClassName: local-storage
resources:
requests:
storage: 5Gi
volumeName: local-pg-pv
EOF
kubectl apply -f ./local-pg-pvc.yml
※Metabase用
cat << EOF > local-metabase-pvc.yml
apiVersion: v1
kind: PersistentVolumeClaim
metadata:
name: local-metabase-pvc
spec:
accessModes:
- ReadWriteOnce
storageClassName: local-storage
resources:
requests:
storage: 5Gi
volumeName: local-metabase-pv
EOF
kubectl apply -f ./local-metabase-pvc.yml
4. MetabaseとPostgrelSQLのDeploymentの作成
以下のコマンドでMetabaseとPostgreSQLを含むポッドと作成したlocal永続ボリュームを使用するDeploymentを作成します。
cat << EOF > metabase-pg-deployment.yml
apiVersion: apps/v1
kind: Deployment
metadata:
name: metabase-pg-deployment
labels:
app: metabase-pg
spec:
replicas: 1
selector:
matchLabels:
app: metabase-pg
strategy:
type: Recreate
template:
metadata:
labels:
app: metabase-pg
spec:
containers:
- name: mypg
image: postgres:14-alpine
env:
- name: POSTGRES_DB
value: metabase
- name: POSTGRES_PASSWORD
value: mypostgres
ports:
- containerPort: 5432
volumeMounts:
- name: pgdata
mountPath: /var/lib/postgresql/data
- name: metabase
image: metabase/metabase
env:
- name: MB_DB_FILE
value: /metabase-data/metabase.db
- name: MB_DB_TYPE
value: postgres
- name: MB_DB_DBNAME
value: metabase
- name: MB_DB_PORT
value: "5432"
- name: MB_DB_USER
value: postgres
- name: MB_DB_PASS
value: mypostgres
- name: MB_DB_HOST
value: 127.0.0.1
ports:
- containerPort: 3000
volumeMounts:
- name: metabase-data
mountPath: /metabase-data
volumes:
- name: pgdata
persistentVolumeClaim:
claimName: local-pg-pvc
- name: metabase-data
persistentVolumeClaim:
claimName: local-metabase-pvc
EOF
kubectl apply -f ./metabase-pg-deployment.yml
5. サービスの作成
以下のコマンドでサービスを作成します。
cat << EOF > metabase-service.yml
apiVersion: v1
kind: Service
metadata:
name: metabase-service
spec:
selector:
app: metabase-pg
ports:
- name: http
protocol: TCP
port: 8080
targetPort: 3000
- name: db
protocol: TCP
port: 5432
targetPort: 5432
EOF
kubectl apply -f ./metabase-service.yml
6. Port-Fowardingで外部からアクセスできるようにする
kubectl port-forward --address 0.0.0.0 service/metabase-service 8080:8080 5432:5432
ブラウザからhttp://<ホスト名:8080 にアクセスします。言語、ユーザアカウント情報を入力して、「3.データを追加する」で以下の様に入力します。
データベースのタイプ: PostgreSQL
名前: pg
ホスト: localhost
ポート: 5432
データベース名: metabase
ユーザ: postgres
パスワード: mypostgres
〇Metabaseの画面
0 件のコメント:
コメントを投稿