ถ้าต้องการสร้าง wordpress + wordpress_db เพื่อเทสใน k8s ก็สามารถทำตามขั้นตอนโดยสรุปได้ดังนี้ครับ
1.ทำการสร้าง PersistentVolumes เพื่อเตรียมไว้ใช้งาน wordpress-static-file และ wordpress_database
2.ทำการสร้าง secret key เพื่อใช้งานกับ mysql 
3.ทำการ deploy file mysql-deployment.yaml และ wordpress-deployment.yaml
4.ทำการเทสเข้า wordpress url 
##วิธีขั้นตอนโดยละเอียด
### Begin of local-volumes.yaml ### 
apiVersion: v1
kind: PersistentVolume
metadata:
  name: local-pv-1
  labels:
    type: local
spec:
  capacity:
    storage: 40Gi
  accessModes:
    - ReadWriteOnce
  hostPath:
    path: /tmp/data/pv-1
---
apiVersion: v1
kind: PersistentVolume
metadata:
  name: local-pv-2
  labels:
    type: local
spec:
  capacity:
    storage: 40Gi
  accessModes:
    - ReadWriteOnce
  hostPath:
    path: /tmp/data/pv-2
### End of local-volumes.yaml ###
ทำการสร้าง persistent volumes
./kubectl create -f local-volumes.yaml
การสร้าง secret-password ใน k8s 
./kubectl create secret generic mysql-pass --from-literal=password=yourpassword
ทำการเช็คว่า secret ที่สร้างแสดงขึ้นมาหรือเปล่า
./kubectl get secrets
###Begin mysql-deployment.yaml ###
apiVersion: v1
kind: Service
metadata:
  name: wordpress-mysql
  labels:
    app: wordpress
spec:
  ports:
    - port: 3306
  selector:
    app: wordpress
    tier: mysql
  clusterIP: None
---
apiVersion: v1
kind: PersistentVolumeClaim
metadata:
  name: mysql-pv-claim
  labels:
    app: wordpress
spec:
  accessModes:
    - ReadWriteOnce
  resources:
    requests:
      storage: 20Gi
---
apiVersion: extensions/v1beta1
kind: Deployment
metadata:
  name: wordpress-mysql
  labels:
    app: wordpress
spec:
  strategy:
    type: Recreate
  template:
    metadata:
      labels:
        app: wordpress
        tier: mysql
    spec:
      containers:
      - image: mysql:5.6
        name: mysql
        env:
          # $ kubectl create secret generic mysql-pass --from-file=password.txt
          # make sure password.txt does not have a trailing newline
        - name: MYSQL_ROOT_PASSWORD
          valueFrom:
            secretKeyRef:
              name: mysql-pass
              key: yourpassword
        ports:
        - containerPort: 3306
          name: mysql
        volumeMounts:
        - name: mysql-persistent-storage
          mountPath: /var/lib/mysql
      volumes:
      - name: mysql-persistent-storage
        persistentVolumeClaim:
          claimName: mysql-pv-claim
###End mysql-deployment.yaml ###
ทำการ deploy MySQL ผ่านไฟล์คอนฟิค mysql-deployment.yaml file:
./kubectl create -f mysql-deployment.yaml
### begin wordpress-deployment.yaml ###
apiVersion: v1
kind: Service
metadata:
  name: wordpress
  labels:
    app: wordpress
spec:
  ports:
    - port: 80
  selector:
    app: wordpress
    tier: frontend
  type: LoadBalancer
---
apiVersion: v1
kind: PersistentVolumeClaim
metadata:
  name: wp-pv-claim
  labels:
    app: wordpress
spec:
  accessModes:
    - ReadWriteOnce
  resources:
    requests:
      storage: 20Gi
---
apiVersion: extensions/v1beta1
kind: Deployment
metadata:
  name: wordpress
  labels:
    app: wordpress
spec:
  strategy:
    type: Recreate
  template:
    metadata:
      labels:
        app: wordpress
        tier: frontend
    spec:
      containers:
      - image: wordpress:4.8.0-apache
        name: wordpress
        env:
        - name: WORDPRESS_DB_HOST
          value: wordpress-mysql
        - name: WORDPRESS_DB_PASSWORD
          valueFrom:
            secretKeyRef:
              name: mysql-pass
              key: password.txt
        ports:
        - containerPort: 80
          name: wordpress
        volumeMounts:
        - name: wordpress-persistent-storage
          mountPath: /var/www/html
      volumes:
      - name: wordpress-persistent-storage
        persistentVolumeClaim:
          claimName: wp-pv-claim
### end wordpress-deployment.yaml ###
ทำการ deploy Wordpress ผ่านไฟล์คอนฟิค wordpress-deployment.yaml file:
./kubectl create -f wordpress-deployment.yaml
ทำการเช็คว่า pods ถูกสร้างขึ้นมาแล้วหรือเปล่า 
./kubectl get pods
รอให้สักประมาณ 50 วินาที แล้วเทสเข้าตัว app wordpress ผ่าน url ที่ขึ้นมาใน k8s dashboard ได้เลยครับ
./kubectl proxy
k8s dashboard binding port proxy => 
http://localhost:8001/uiถ้าจะทำการลบ secret ผ่าน cli ก็
./kubectl delete secret mysql-pass
ถ้าจะทำการลบ deployment app สามารถรันผ่าน cli ตามด้านล่างครับ ใส่ชื่อ app=ชื่อappที่ต้องการลบ
./kubectl delete deployment -l app=wordpress
./kubectl delete service -l app=wordpress
ทำการลบ PersistentVolumeClaim  และ PersistentVolumes:
./kubectl delete pvc -l app=wordpress
./kubectl delete pv local-pv-1 local-pv-2
กอล์ฟ [at] packetlove.com
#k8strainingbypacketlove #kubernetestraining