2022年2月6日日曜日

MinikubeとHelmでlocal永続ボリュームを使用するPostgreSQLをデプロイする

MinikubeとHelmでlocal永続ボリュームを使用するPostgreSQLをデプロイするには、以下の手順を実行します。

実行手順

1. PostgreSQLデータ格納用ディレクトリを作成
以下のコマンドでPostgreSQLデータ格納用ディレクトリを作成します。
minikube ssh

sudo mkdir -p /var/pgdata

exit

2. local永続ボリュームの作成
以下のコマンドでlocal永続ボリュームを作成します。
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

3. 永続ボリューム要求の作成
以下のコマンドで永続ボリューム要求を作成します。
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

4. HelmでPostgreSQLのインストール
以下のコマンドで、Helmを使用してPostgreSQLをインストールします。
helm repo update

helm install my-pg bitnami/postgresql --set persistence.existingClaimm=local-pg-pvc --set postgresqlPassword=mypg

パラメータについては、以下を指定します。
persistence.existingClaim: 永続ボリューム要求の名称
postgresqlPassword: postgresユーザのパスワード

他のパラメータについては、以下を参照してください
https://github.com/bitnami/charts/tree/master/bitnami/postgresql

※アンインストールする場合は、以下のコマンドを実行します。
helm uninstall my-pg

5. Port-Fowardingで外部からアクセスできるようにする
kubectl port-forward --address 0.0.0.0 service/my-pg-postgresql 5432:5432

※接続確認
psql -h ※MinikubeをインストールしたホストのIP -U postgres -W postgres

※PostgreSQLのクライアントは以下のコマンドでインストールできます。
sudo apt-get -y install postgresql-client

0 件のコメント:

コメントを投稿