k8s上创建mysql
时间: 2023-08-28 22:10:52 浏览: 106
在 Kubernetes(k8s)上创建 MySQL 可以通过以下步骤完成:
1. 创建一个 MySQL 的配置文件,如 `mysql-deployment.yaml`,并添加以下内容:
```yaml
apiVersion: v1
kind: PersistentVolumeClaim
metadata:
name: mysql-pvc
spec:
accessModes:
- ReadWriteOnce
resources:
requests:
storage: 1Gi
---
apiVersion: v1
kind: Service
metadata:
name: mysql-service
spec:
ports:
- port: 3306
selector:
app: mysql
type: ClusterIP
---
apiVersion: apps/v1
kind: Deployment
metadata:
name: mysql-deployment
spec:
replicas: 1
selector:
matchLabels:
app: mysql
template:
metadata:
labels:
app: mysql
spec:
containers:
- name: mysql
image: mysql:latest
ports:
- containerPort: 3306
env:
- name: MYSQL_ROOT_PASSWORD
valueFrom:
secretKeyRef:
name: mysql-secret
key: password
volumeMounts:
- mountPath: /var/lib/mysql
name: mysql-volume
volumes:
- name: mysql-volume
persistentVolumeClaim:
claimName: mysql-pvc
---
apiVersion: v1
kind: Secret
metadata:
name: mysql-secret
type: Opaque
data:
password: BASE64_ENCODED_PASSWORD
```
2. 替换 `BASE64_ENCODED_PASSWORD` 为你的 MySQL root 密码的 Base64 编码。
3. 使用 `kubectl apply` 命令应用配置文件:
```bash
kubectl apply -f mysql-deployment.yaml
```
这将创建一个包含 MySQL 的 Deployment、Service 和 PersistentVolumeClaim。
注意:上述配置只是一个基本示例,你可能需要根据你的环境和需求进行适当的修改。另外,建议在生产环境中使用更加安全的方式来管理密码,例如使用 Kubernetes 的 Secrets。
希望这能帮到你!如果你有任何疑问,请随时提问。
阅读全文