k8s 之如何创建一个WordPress

方法一:nodePort + haproxy 外网访问 WordPress

1. 创建 StorageClass、Namespace 和 pvc 资源

1.1 创建 StorageClass

  • 创建命令
$ kubectl  create -f sc.yaml
$ kubectl get sc 
NAME                  PROVISIONER       AGE
wordpress-sc-001      cds/nas           30m
  • sc.yaml 内容如下
apiVersion: storage.k8s.io/v1
kind: StorageClass
metadata:
  name: wordpress-sc-001
provisioner: cds/nas
parameters:
  archiveOnDelete: "false"
  server: "164.52.43.137"               # 替换为集群配置的存储NAS云盘ip地址
  path: "/nfsshare/wordpress"       # 目录可自行修改为 /nfssahre/<dirName> 
  vers: "4.0"
  mode: "777"
reclaimPolicy: "Delete"

1.2 创建Namespace 和 pvc

  • 创建命令
$ kubectl  create -f wordpress-storageclass-pvc.yaml
  • wordpress-storageclass-pvc.yaml 内容如下
apiVersion: v1
kind: Namespace
metadata:
   name: wordpress
   labels:
     app: wordpress
 ---
apiVersion: v1
kind: PersistentVolumeClaim
metadata:
  name: mysql-pv-claim
  namespace: wordpress
  labels:
    app: wordpress
spec:
  accessModes:
    - ReadWriteOnce
  resources:
    requests:
      storage: 20Gi
  storageClassName: wordpress-sc-001

---
apiVersion: v1
kind: PersistentVolumeClaim
metadata:
  name: wp-pv-claim
  namespace: wordpress
  labels:
    app: wordpress
spec:
  accessModes:
    - ReadWriteOnce
  resources:
    requests:
      storage: 20Gi
  storageClassName: wordpress-sc-001

2. 部署MySQL容器组

  • 创建一个Secret变量存放MySQL密码
$ kubectl create secret generic mysql-pass --from-literal=password=<YOUR_PASSWORD> -n <NAMESPACE>
$ kubectl get secret -n wordpress
NAME                  TYPE                                  DATA   AGE
default-token-5k6fs   kubernetes.io/service-account-token   3      43m
mysql-pass            Opaque                                1      41m
  • 部署MySQL容器
$ kubectl create -f mysql-deployment.yaml
  • mysql-deployment.yaml 内容如下
apiVersion: v1
kind: Service
metadata:
  name: wordpress-mysql
  namespace: wordpress
  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: apps/v1 # for versions before 1.9.0 use apps/v1beta2
kind: Deployment
metadata:
  name: wordpress-mysql
  namespace: wordpress
  labels:
    app: wordpress
spec:
  selector:
    matchLabels:
      app: wordpress
      tier: mysql
  strategy:
    type: Recreate
  template:
    metadata:
      labels:
        app: wordpress
        tier: mysql
    spec:
      containers:
      - image: mysql:5.6
        name: mysql
        env:
        - name: MYSQL_ROOT_PASSWORD
          valueFrom:
            secretKeyRef:
              name: mysql-pass
              key: password
        ports:
        - containerPort: 3306
          name: mysql
        volumeMounts:
        - name: mysql-persistent-storage
          mountPath: /var/lib/mysql
      volumes:
      - name: mysql-persistent-storage
        persistentVolumeClaim:
          claimName: mysql-pv-claim
  • 检查MySQL部署情况
$ kubectl  get deployment -n wordpress
NAME              READY   UP-TO-DATE   AVAILABLE   AGE
wordpress-mysql   1/1     1            1           39m
$ kubectl  get pods -n wordpress
NAME                               READY   STATUS    RESTARTS   AGE
wordpress-mysql-5b697dbbfc-5rwrl   1/1     Running   0          39m

3. 部署WordPress容器组

  • 部署命令
$ kubectl create -f wordpress-deployment.yaml
  • wordpress-deployment.yaml 内容如下
apiVersion: v1
kind: Service
metadata:
  name: wordpress
  namespace: wordpress
  labels:
    app: wordpress
spec:
  type: NodePort                        # 设置 NodePort 方式访问 Wordpress
  ports:
    - port: 80
      targetPort: 80
      nodePort: 30080               # 设置映射端口为 30080 
  selector:
    app: wordpress
    tier: frontend
---
apiVersion: apps/v1 # for versions before 1.9.0 use apps/v1beta2
kind: Deployment
metadata:
  name: wordpress
  namespace: wordpress
  labels:
    app: wordpress
spec:
  selector:
    matchLabels:
      app: wordpress
      tier: frontend
  strategy:
    type: Recreate
  template:
    metadata
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
使用Kubernetes(简称K8s)部署WordPress可以提供高可用性和可扩展性。下面是一个基本的步骤: 1. 配置Kubernetes集群:确保你已经有一个可用的Kubernetes集群,可以使用工具如Minikube、kubeadm或云服务提供商的托管服务。 2. 创建命名空间:为WordPress创建一个命名空间,可以使用以下命令: ``` kubectl create namespace wordpress ``` 3. 创建MySQL数据库:WordPress需要一个MySQL数据库来存储数据。可以使用Kubernetes的StatefulSet来创建一个MySQL实例。创建一个MySQL的配置文件(例如mysql.yaml),示例如下: ```yaml apiVersion: v1 kind: Service metadata: name: mysql namespace: wordpress spec: selector: app: mysql ports: - protocol: TCP port: 3306 targetPort: 3306 --- apiVersion: apps/v1 kind: StatefulSet metadata: name: mysql namespace: wordpress spec: serviceName: mysql replicas: 1 selector: matchLabels: app: mysql template: metadata: labels: app: mysql spec: containers: - name: mysql image: mysql:5.7 env: - name: MYSQL_ROOT_PASSWORD value: your_password_here ports: - containerPort: 3306 name: mysql volumeMounts: - name: mysql-persistent-storage mountPath: /var/lib/mysql volumes: - name: mysql-persistent-storage persistentVolumeClaim: claimName: mysql-pv-claim ``` 使用以下命令创建MySQL实例: ``` kubectl apply -f mysql.yaml ``` 4. 创建WordPress应用:创建一个WordPress的配置文件(例如wordpress.yaml),示例如下: ```yaml apiVersion: v1 kind: Service metadata: name: wordpress namespace: wordpress spec: selector: app: wordpress ports: - protocol: TCP port: 80 targetPort: 80 --- apiVersion: apps/v1 kind: Deployment metadata: name: wordpress namespace: wordpress spec: replicas: 1 selector: matchLabels: app: wordpress template: metadata: labels: app: wordpress spec: containers: - name: wordpress image: wordpress:latest env: - name: WORDPRESS_DB_HOST value: mysql - name: WORDPRESS_DB_PASSWORD value: your_password_here ports: - containerPort: 80 name: wordpress ``` 使用以下命令创建WordPress应用: ``` kubectl apply -f wordpress.yaml ``` 5. 配置Ingress:为了让WordPress可以通过域名访问,需要配置Ingress。创建一个Ingress的配置文件(例如ingress.yaml),示例如下: ```yaml apiVersion: networking.k8s.io/v1beta1 kind: Ingress metadata: name: wordpress-ingress namespace: wordpress spec: rules: - host: your_domain_here http: paths: - path: / backend: serviceName: wordpress servicePort: 80 ``` 使用以下命令创建Ingress: ``` kubectl apply -f ingress.yaml ``` 6. 配置DNS解析:将你的域名解析到Kubernetes集群的Ingress IP地址。 现在,你可以通过访问你的域名来访问WordPress了。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值