kubernetes เทสลง wordpress app และ mysql-database

kubernetes เทสลง wordpress app และ mysql-database
ถ้าต้องการสร้าง 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

Add A Comment

メールアドレスが公開されることはありません。 * が付いている欄は必須項目です