在Kubernetes环境中使用PHP与MySQL配合,通常涉及以下几个步骤:
1. 准备MySQL服务
首先,你需要在Kubernetes集群中部署一个MySQL服务。你可以使用MySQL的官方Docker镜像,并通过Kubernetes的Deployment和Service资源来管理它。
MySQL Deployment
创建一个名为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
创建一个名为mysql-service.yaml
的文件,内容如下:
apiVersion: v1 kind: Service metadata: name: mysql-service spec: selector: app: mysql ports: - protocol: TCP port: 3306 targetPort: 3306 type: ClusterIP
2. 准备PHP应用
接下来,你需要准备一个PHP应用,该应用将连接到上面部署的MySQL服务。
假设你有一个简单的PHP应用,使用mysqli
扩展连接到MySQL数据库。你可以创建一个名为php-app.php
的文件,内容如下:
connect_error) { die("连接失败: " . $conn->connect_error); } echo "连接成功"; $conn->close(); ?>
3. 部署PHP应用
在Kubernetes集群中部署你的PHP应用。你可以使用与MySQL相同的Deployment和Service资源,或者为PHP应用创建新的资源。
PHP App Deployment
创建一个名为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
创建一个名为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
4. 配置持久化存储
为了确保数据在容器重启或集群节点故障时不会丢失,你需要配置持久化存储。
MySQL Persistent Volume Claim
创建一个名为mysql-pvc.yaml
的文件,内容如下:
apiVersion: v1 kind: PersistentVolumeClaim metadata: name: mysql-pvc spec: accessModes: - ReadWriteOnce resources: requests: storage: 10Gi
PHP App Persistent Volume Claim
创建一个名为php-app-pvc.yaml
的文件,内容如下:
apiVersion: v1 kind: PersistentVolumeClaim metadata: name: php-app-pvc spec: accessModes: - ReadWriteOnce resources: requests: storage: 1Gi
5. 应用配置
最后,应用上述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集群中运行。