〇Adminerの画面
実行手順
1. PostgreSQLデータ格納用ディレクトリを作成以下のコマンドでPostgreSQLデータ格納用ディレクトリを作成します。
sudo mkdir -p /var/pgdata
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:
- `hostname`
EOF
※`hostname`は今ログオンしているMicrok8sがインストールされているホスト名になります。適宜変更してください。microk8s 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
microk8s kubectl apply -f ./local-pg-pvc.yml
4. AdminerとPostgrelSQLのDeploymentの作成
以下のコマンドでadminerとPostgreSQLを含むポッドと作成したlocal永続ボリュームを使用するDeploymentを作成します。
cat << EOF > adminer-pg-deployment.yml
apiVersion: apps/v1
kind: Deployment
metadata:
name: adminer-pg-deployment
labels:
app: adminer-pg
spec:
replicas: 1
selector:
matchLabels:
app: adminer-pg
strategy:
type: Recreate
template:
metadata:
labels:
app: adminer-pg
spec:
containers:
- name: mypg
image: postgres:14-alpine
env:
- name: POSTGRES_PASSWORD
value: mypostgres
ports:
- containerPort: 5432
volumeMounts:
- name: pgdata
mountPath: /var/lib/postgresql/data
- name: adminer
image: adminer:4-standalone
env:
- name: ADMINER_DEFAULT_SERVER
value: xxx.xxx.xxx.xxx # ホストのIPアドレス
ports:
- containerPort: 8080
volumes:
- name: pgdata
persistentVolumeClaim:
claimName: local-pg-pvc
EOF
microk8s kubectl apply -f ./adminer-pg-deployment.yml
5. AdminerとPostgreSQLのサービスの作成
以下のコマンドでサービスを作成します。
cat << EOF > adminer-pg-service.yml
apiVersion: v1
kind: Service
metadata:
name: adminer-pg-service
spec:
selector:
app: adminer-pg
type: LoadBalancer
externalIPs:
- xxx.xxx.xx.xxx # 外部からアクセスできるMicrok8sをインストールしたホストのIPを設定します。
ports:
- name: http
protocol: TCP
port: 8080
targetPort: 8080
- name: db
protocol: TCP
port: 5432
targetPort: 5432
EOF
microk8s kubectl apply -f ./adminer-pg-service.yml
ブラウザから以下のURLからAdminerにアクセスします。
http://<Microk8sをインストールしたホストのIP>:8080/
ログインフォームでは、以下を選択します。
データベース種類: PostgreSQL
サーバ: 127.0.0.1
ユーザ名: postgres
パスワード: mypostgres
データベース: postgres
0 件のコメント:
コメントを投稿