在Kubernetes環境中使用PHP與MySQL配合,通常涉及以下幾個步驟:
首先,你需要在Kubernetes集群中部署一個MySQL服務。你可以使用MySQL的官方Docker鏡像,并通過Kubernetes的Deployment和Service資源來管理它。
創建一個名為mysql-deployment.yaml
的文件,內容如下:
apiVersion: apps/v1
kind: Deployment
metadata:
name: mysql-deployment
spec:
selector:
matchLabels:
app: mysql
replicas: 1
template:
metadata:
labels:
app: mysql
spec:
containers:
- name: mysql
image: mysql:8.0
ports:
- containerPort: 3306
env:
- name: MYSQL_ROOT_PASSWORD
valueFrom:
secretKeyRef:
name: mysql-secret
key: password
volumeMounts:
- name: mysql-persistent-storage
mountPath: /var/lib/mysql
volumes:
- name: mysql-persistent-storage
persistentVolumeClaim:
claimName: mysql-pvc
創建一個名為mysql-service.yaml
的文件,內容如下:
apiVersion: v1
kind: Service
metadata:
name: mysql-service
spec:
selector:
app: mysql
ports:
- protocol: TCP
port: 3306
targetPort: 3306
type: ClusterIP
接下來,你需要準備一個PHP應用,該應用將連接到上面部署的MySQL服務。
假設你有一個簡單的PHP應用,使用mysqli
擴展連接到MySQL數據庫。你可以創建一個名為php-app.php
的文件,內容如下:
<?php
$servername = "mysql-service";
$username = "your_username";
$password = "your_password";
$dbname = "your_database";
// 創建連接
$conn = new mysqli($servername, $username, $password, $dbname);
// 檢測連接
if ($conn->connect_error) {
die("連接失敗: " . $conn->connect_error);
}
echo "連接成功";
$conn->close();
?>
在Kubernetes集群中部署你的PHP應用。你可以使用與MySQL相同的Deployment和Service資源,或者為PHP應用創建新的資源。
創建一個名為php-app-deployment.yaml
的文件,內容如下:
apiVersion: apps/v1
kind: Deployment
metadata:
name: php-app-deployment
spec:
selector:
matchLabels:
app: php-app
replicas: 1
template:
metadata:
labels:
app: php-app
spec:
containers:
- name: php-app
image: your-php-image:tag
ports:
- containerPort: 80
env:
- name: DB_SERVER
value: mysql-service
- name: DB_USERNAME
value: your_username
- name: DB_PASSWORD
value: your_password
- name: DB_NAME
value: your_database
volumeMounts:
- name: php-app-storage
mountPath: /usr/src/app
volumes:
- name: php-app-storage
persistentVolumeClaim:
claimName: php-app-pvc
創建一個名為php-app-service.yaml
的文件,內容如下:
apiVersion: v1
kind: Service
metadata:
name: php-app-service
spec:
selector:
app: php-app
ports:
- protocol: TCP
port: 80
targetPort: 80
type: LoadBalancer
為了確保數據在容器重啟或集群節點故障時不會丟失,你需要配置持久化存儲。
創建一個名為mysql-pvc.yaml
的文件,內容如下:
apiVersion: v1
kind: PersistentVolumeClaim
metadata:
name: mysql-pvc
spec:
accessModes:
- ReadWriteOnce
resources:
requests:
storage: 10Gi
創建一個名為php-app-pvc.yaml
的文件,內容如下:
apiVersion: v1
kind: PersistentVolumeClaim
metadata:
name: php-app-pvc
spec:
accessModes:
- ReadWriteOnce
resources:
requests:
storage: 1Gi
最后,應用上述YAML文件到Kubernetes集群中:
kubectl apply -f mysql-deployment.yaml
kubectl apply -f mysql-service.yaml
kubectl apply -f php-app-deployment.yaml
kubectl apply -f php-app-service.yaml
kubectl apply -f mysql-pvc.yaml
kubectl apply -f php-app-pvc.yaml
現在,你的PHP應用應該能夠成功連接到MySQL服務,并在Kubernetes集群中運行。