kubernetes php與mysql配合使用

sql
小樊
81
2024-09-26 20:05:35
欄目: 云計(jì)算

在Kubernetes環(huán)境中使用PHP與MySQL配合,通常涉及以下幾個(gè)步驟:

1. 準(zhǔn)備MySQL服務(wù)

首先,你需要在Kubernetes集群中部署一個(gè)MySQL服務(wù)。你可以使用MySQL的官方Docker鏡像,并通過(guò)Kubernetes的Deployment和Service資源來(lái)管理它。

MySQL Deployment

創(chuàng)建一個(gè)名為mysql-deployment.yaml的文件,內(nèi)容如下:

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

創(chuàng)建一個(gè)名為mysql-service.yaml的文件,內(nèi)容如下:

apiVersion: v1
kind: Service
metadata:
  name: mysql-service
spec:
  selector:
    app: mysql
  ports:
    - protocol: TCP
      port: 3306
      targetPort: 3306
  type: ClusterIP

2. 準(zhǔn)備PHP應(yīng)用

接下來(lái),你需要準(zhǔn)備一個(gè)PHP應(yīng)用,該應(yīng)用將連接到上面部署的MySQL服務(wù)。

假設(shè)你有一個(gè)簡(jiǎn)單的PHP應(yīng)用,使用mysqli擴(kuò)展連接到MySQL數(shù)據(jù)庫(kù)。你可以創(chuàng)建一個(gè)名為php-app.php的文件,內(nèi)容如下:

<?php
$servername = "mysql-service";
$username = "your_username";
$password = "your_password";
$dbname = "your_database";

// 創(chuàng)建連接
$conn = new mysqli($servername, $username, $password, $dbname);

// 檢測(cè)連接
if ($conn->connect_error) {
    die("連接失敗: " . $conn->connect_error);
}
echo "連接成功";
$conn->close();
?>

3. 部署PHP應(yīng)用

在Kubernetes集群中部署你的PHP應(yīng)用。你可以使用與MySQL相同的Deployment和Service資源,或者為PHP應(yīng)用創(chuàng)建新的資源。

PHP App Deployment

創(chuàng)建一個(gè)名為php-app-deployment.yaml的文件,內(nèi)容如下:

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

創(chuàng)建一個(gè)名為php-app-service.yaml的文件,內(nèi)容如下:

apiVersion: v1
kind: Service
metadata:
  name: php-app-service
spec:
  selector:
    app: php-app
  ports:
    - protocol: TCP
      port: 80
      targetPort: 80
  type: LoadBalancer

4. 配置持久化存儲(chǔ)

為了確保數(shù)據(jù)在容器重啟或集群節(jié)點(diǎn)故障時(shí)不會(huì)丟失,你需要配置持久化存儲(chǔ)。

MySQL Persistent Volume Claim

創(chuàng)建一個(gè)名為mysql-pvc.yaml的文件,內(nèi)容如下:

apiVersion: v1
kind: PersistentVolumeClaim
metadata:
  name: mysql-pvc
spec:
  accessModes:
    - ReadWriteOnce
  resources:
    requests:
      storage: 10Gi

PHP App Persistent Volume Claim

創(chuàng)建一個(gè)名為php-app-pvc.yaml的文件,內(nèi)容如下:

apiVersion: v1
kind: PersistentVolumeClaim
metadata:
  name: php-app-pvc
spec:
  accessModes:
    - ReadWriteOnce
  resources:
    requests:
      storage: 1Gi

5. 應(yīng)用配置

最后,應(yīng)用上述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

現(xiàn)在,你的PHP應(yīng)用應(yīng)該能夠成功連接到MySQL服務(wù),并在Kubernetes集群中運(yùn)行。

0