示例:使用 Redis 部署 PHP 留言板应用程序

    • 单实例 Redis 主节点保存留言板条目
    • 多个 节点用来读取数据
    • 多个 web 前端实例
    • 启动 Redis 主节点。
    • 启动 Redis 从节点。
    • 启动留言板前端。
    • 公开并查看前端服务。
    • 清理。

    准备开始

    你必须拥有一个 Kubernetes 的集群,同时你的 Kubernetes 集群必须带有 kubectl 命令行工具。如果你还没有集群,你可以通过 构建一个你自己的集群,或者你可以使用下面任意一个 Kubernetes 工具构建:

    要获知版本信息,请输入 .

    留言板应用程序使用 Redis 存储数据。它将数据写入一个 Redis 主实例,并从多个 Redis 读取数据。

    下面包含的清单文件指定了一个 Deployment 控制器,该控制器运行一个 Redis 主节点 Pod 副本。

    • 在下载清单文件的目录中启动终端窗口。
    • redis-master-deployment.yaml 文件中应用 Redis 主 Deployment:
    1. kubectl apply -f https://k8s.io/examples/application/guestbook/redis-master-deployment.yaml
    • 查询 Pod 列表以验证 Redis 主节点 Pod 是否正在运行:
    1. kubectl get pods
    1. 响应应该与此类似:
    2. ```shell
    3. NAME READY STATUS RESTARTS AGE
    4. redis-master-1068406935-3lswp 1/1 Running 0 28s
    5. ```
    • 运行以下命令查看 Redis 主节点 Pod 中的日志:
    1. kubectl logs -f POD-NAME

    创建 Redis 主节点的服务

    1. apiVersion: v1kind: Servicemetadata: name: redis-master labels: app: redis role: master tier: backendspec: ports: - port: 6379 targetPort: 6379 selector: app: redis role: master tier: backend
    • 使用下面的 redis-master-service.yaml 文件创建 Redis 主节点的服务:
    1. kubectl apply -f https://k8s.io/examples/application/guestbook/redis-master-service.yaml
    • 查询服务列表验证 Redis 主节点服务是否正在运行:
    1. kubectl get service
    1. 响应应该与此类似:
    2. ```shell
    3. NAME TYPE CLUSTER-IP EXTERNAL-IP PORT(S) AGE
    4. kubernetes ClusterIP 10.0.0.1 <none> 443/TCP 1m
    5. redis-master ClusterIP 10.0.0.151 <none> 6379/TCP 8s
    6. ```

    启动 Redis 从节点

    尽管 Redis 主节点是一个单独的 pod,但是您可以通过添加 Redis 从节点的方式来使其高可用性,以满足流量需求。

    Deployments 根据清单文件中设置的配置进行伸缩。在这种情况下,Deployment 对象指定两个副本。

    如果没有任何副本正在运行,则此 Deployment 将启动容器集群上的两个副本。相反,如果有两个以上的副本在运行,那么它的规模就会缩小,直到运行两个副本为止。

    • redis-slave-deployment.yaml 文件中应用 Redis Slave Deployment:
    1. kubectl apply -f https://k8s.io/examples/application/guestbook/redis-slave-deployment.yaml
    • 查询 Pod 列表以验证 Redis Slave Pod 正在运行:
    1. kubectl get pods
    1. 响应应该与此类似:
    2. ```shell
    3. NAME READY STATUS RESTARTS AGE
    4. redis-master-1068406935-3lswp 1/1 Running 0 1m
    5. redis-slave-2005841000-fpvqc 0/1 ContainerCreating 0 6s
    6. redis-slave-2005841000-phfv9 0/1 ContainerCreating 0 6s
    7. ```

    创建 Redis 从节点的 Service

    留言板应用程序需要从 Redis 从节点中读取数据。为了便于 Redis 从节点可发现,您需要设置一个 Service。Service 为一组 Pod 提供负载均衡。

    application/guestbook/redis-slave-service.yaml示例:使用 Redis 部署 PHP 留言板应用程序 - 图4
    • 从以下 redis-slave-service.yaml 文件应用 Redis Slave 服务:
    1. kubectl apply -f https://k8s.io/examples/application/guestbook/redis-slave-service.yaml
    • 查询服务列表以验证 Redis 在服务是否正在运行:
    1. kubectl get services
    1. 响应应该与此类似:
    2. ```
    3. NAME TYPE CLUSTER-IP EXTERNAL-IP PORT(S) AGE
    4. redis-master ClusterIP 10.0.0.151 <none> 6379/TCP 1m
    5. redis-slave ClusterIP 10.0.0.223 <none> 6379/TCP 6s
    6. ```
    • frontend-deployment.yaml 应用前端 Deployment 文件:
    1. kubectl apply -f https://k8s.io/examples/application/guestbook/frontend-deployment.yaml
    • 查询 Pod 列表,验证三个前端副本是否正在运行:
    1. kubectl get pods -l app=guestbook -l tier=frontend
    1. 响应应该与此类似:
    2. ```
    3. NAME READY STATUS RESTARTS AGE
    4. frontend-3823415956-dsvc5 1/1 Running 0 54s
    5. frontend-3823415956-k22zn 1/1 Running 0 54s
    6. frontend-3823415956-w9gbt 1/1 Running 0 54s
    7. ```

    创建前端服务

    应用的 redis-slaveredis-master 服务只能在容器集群中访问,因为服务的默认类型是ClusterIPClusterIP 为服务指向的 Pod 集提供一个 IP 地址。这个 IP 地址只能在集群中访问。

    如果您希望客人能够访问您的留言板,您必须将前端服务配置为外部可见的,以便客户机可以从容器集群之外请求服务。Minikube 只能通过 NodePort 公开服务。

    1. apiVersion: v1kind: Servicemetadata: name: frontend labels: app: guestbook tier: frontendspec: # comment or delete the following line if you want to use a LoadBalancer type: NodePort # if your cluster supports it, uncomment the following to automatically create # an external load-balanced IP for the frontend service. # type: LoadBalancer ports: - port: 80 selector: app: guestbook tier: frontend
    • frontend-service.yaml 文件中应用前端服务:
    1. kubectl apply -f https://k8s.io/examples/application/guestbook/frontend-service.yaml
    • 查询服务列表以验证前端服务正在运行:
    1. kubectl get services
    1. 响应应该与此类似:
    2. ```
    3. NAME TYPE CLUSTER-IP EXTERNAL-IP PORT(S) AGE
    4. frontend ClusterIP 10.0.0.112 <none> 80:31323/TCP 6s
    5. kubernetes ClusterIP 10.0.0.1 <none> 443/TCP 4m
    6. redis-master ClusterIP 10.0.0.151 <none> 6379/TCP 2m
    7. redis-slave ClusterIP 10.0.0.223 <none> 6379/TCP 1m
    8. ```

    如果您将此应用程序部署到 Minikube 或本地集群,您需要找到 IP 地址来查看您的留言板。

    • 运行以下命令获取前端服务的 IP 地址。
    1. minikube service frontend --url
    • 复制 IP 地址,然后在浏览器中加载页面以查看留言板。

    通过 LoadBalancer 查看前端服务

    如果您部署了 frontend-service.yaml。你需要找到 IP 地址来查看你的留言板。

    • 运行以下命令以获取前端服务的 IP 地址。
    1. kubectl get service frontend
    1. 响应应该与此类似:
    2. ```
    3. ```
    • 复制外部 IP 地址,然后在浏览器中加载页面以查看留言板。

    扩展 Web 前端

    • 运行以下命令扩展前端 Pod 的数量:
    1. kubectl scale deployment frontend --replicas=5
    • 查询 Pod 列表验证正在运行的前端 Pod 的数量:
    1. kubectl get pods
    1. 响应应该类似于这样:
    2. ```
    3. NAME READY STATUS RESTARTS AGE
    4. frontend-3823415956-70qj5 1/1 Running 0 5s
    5. frontend-3823415956-dsvc5 1/1 Running 0 54m
    6. frontend-3823415956-k22zn 1/1 Running 0 54m
    7. frontend-3823415956-w9gbt 1/1 Running 0 54m
    8. frontend-3823415956-x2pld 1/1 Running 0 5s
    9. redis-master-1068406935-3lswp 1/1 Running 0 56m
    10. redis-slave-2005841000-fpvqc 1/1 Running 0 55m
    11. redis-slave-2005841000-phfv9 1/1 Running 0 55m
    12. ```
    • 运行以下命令缩小前端 Pod 的数量:
    1. kubectl scale deployment frontend --replicas=2
    • 查询 Pod 列表验证正在运行的前端 Pod 的数量:
    1. kubectl get pods
    1. 响应应该类似于这样:
    2. ```
    3. NAME READY STATUS RESTARTS AGE
    4. frontend-3823415956-k22zn 1/1 Running 0 1h
    5. frontend-3823415956-w9gbt 1/1 Running 0 1h
    6. redis-master-1068406935-3lswp 1/1 Running 0 1h
    7. redis-slave-2005841000-fpvqc 1/1 Running 0 1h
    8. redis-slave-2005841000-phfv9 1/1 Running 0 1h
    9. ```

    删除 Deployments 和服务还会删除正在运行的 Pod。使用标签用一个命令删除多个资源。

    • 运行以下命令以删除所有 Pod,Deployments 和 Services。
    1. kubectl delete deployment -l app=redis
    2. kubectl delete service -l app=redis
    3. kubectl delete deployment -l app=guestbook
    4. kubectl delete service -l app=guestbook
    1. 响应应该是:
    2. ```
    3. deployment.apps "redis-master" deleted
    4. deployment.apps "redis-slave" deleted
    5. service "redis-master" deleted
    6. service "redis-slave" deleted
    7. deployment.apps "frontend" deleted
    8. service "frontend" deleted
    9. ```
    • 查询 Pod 列表,确认没有 Pod 在运行:
    1. kubectl get pods
    1. 响应应该是:
    2. ```
    3. ```

    接下来