K8S自己动手系列 - 2.1 - Pod

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
RDS MySQL Serverless 高可用系列,价值2615元额度,1个月
云数据库 RDS PostgreSQL,高可用系列 2核4GB
简介: 从本篇开始,作者以一个具体案例wordpress+mysql搭建博客为例,介绍Kubernetes的各项功能在实际应用当中的使用技巧

说在最前

Pod作为Kubernetes的一等公民,是K8S调度的最小单元,也是使用Kubernetes的人打交道最多的K8S模型。既然Pod这么重要,搞清楚Pod的各种功能及操作就非常重要了,理解了Pod以后,各种Pod的控制器组件,例如:Deployment,StatefulSet,DaemonSet, Job,ReplicaSet理解起来才能事半功倍。

正篇

阅读官方文档对Pod的描述,其阐述了Pod在集群中的两种主要使用方式:

  • 一个Pod运行一个容器
  • 一个Pod运行多个需要在一起的容器

由于前面的实验,我们已经使用过Deployment部署简单的nginx容器,这种就属于第一种,一个Pod运行一个容器的模型,所以本篇文章我们来实战一下,一个Pod运行多个相互关联的容器。

实战

场景说明

本文以常用blog应用wordpress+mysql为例,将wordpress与mysql运行在同一个Pod内,并实现同Pod的相互访问。

本文实验所有的源码保存在:
https://github.com/zrbcool/blog-public/tree/master/k8s-hands-on/lab04

创建wordpress的Pod

查看Pod的yaml定义:

  lab04 git:(master) cat 01-wordpress-pod.yaml 
apiVersion: v1
kind: Pod
metadata:
  labels:
    app: wordpress
  name: wordpress 
spec:
  containers:
  - image: wordpress:latest 
    imagePullPolicy: IfNotPresent
    name: wordpress

部署该Pod,并查看运行状态

  lab04 kubectl apply -f 01-wordpress-pod.yaml
pod/wordpress create
  lab04 kubectl get pods -o wide
NAME        READY   STATUS    RESTARTS   AGE     IP            NODE       NOMINATED NODE   READINESS GATES
wordpress   1/1     Running   0          2m21s   10.244.0.53   worker01   <none>           <none>
  lab04 http 10.244.0.53 
HTTP/1.1 302 Found
Connection: Keep-Alive
Content-Length: 0
Content-Type: text/html; charset=UTF-8
Date: Mon, 10 Jun 2019 05:37:54 GMT
Keep-Alive: timeout=5, max=100
Location: http://10.244.0.53/wp-admin/setup-config.php
Server: Apache/2.4.25 (Debian)
X-Powered-By: PHP/7.3.6

为了方便访问,我们再创建一个类型为NodePort的Service(这块不用纠结,后面会专门讲到),

  lab04 git:(master) cat 02-wordpress-svc.yaml 
apiVersion: v1
kind: Service
metadata:
  name: wordpress-svc 
  labels:
    app: wordpress
spec:
  ports:
  - port: 80
    protocol: TCP
    targetPort: 80
  selector:
    app: wordpress
  type: NodePort

  lab04 kubectl apply -f 02-wordpress-svc.yaml 
service/wordpress-svc created
  lab04 kubectl get svc wordpress-svc
NAME            TYPE       CLUSTER-IP    EXTERNAL-IP   PORT(S)        AGE
wordpress-svc   NodePort   10.98.40.11   <none>        80:30466/TCP   108s

然后我们用节点IP:30466就可以进行访问了,试试

加入mysql的Pod

上面的步骤,我们成功使用Pod资源模型部署了wordpress,但是wordpress是基于mysql的应用,我们还需要一个mysql,针对这个实验,我们将mysql与wordpress部署在一个pod,这样他们就可以基于localhost进行通信了,来试试看。

修改Pod定义,加入mysql

修改后的yaml请参考:

  lab04 git:(master) cat 03-wordpress-mysql-pod.yaml 
apiVersion: v1
kind: Pod
metadata:
  labels:
    app: wordpress
  name: wordpress 
spec:
  containers:
  - image: wordpress:latest 
    imagePullPolicy: IfNotPresent
    name: wordpress
  - image: mysql:5.7.26
    imagePullPolicy: IfNotPresent
    name: mysql
    env:
      - name: MYSQL_ROOT_PASSWORD 
        value: "passw0rd"

执行部署,

  lab04 kubectl delete -f 03-wordpress-mysql-pod.yaml
pod "wordpress" deleted
  lab04 kubectl create -f 03-wordpress-mysql-pod.yaml
pod/wordpress created
  lab04 kubectl get pods -o wide
NAME        READY   STATUS    RESTARTS   AGE   IP            NODE       NOMINATED NODE   READINESS GATES
wordpress   2/2     Running   0          25s   10.244.0.55   worker01   <none>           <none>

  lab04 telnet 10.244.0.55 3306
Trying 10.244.0.55...
Connected to 10.244.0.55.
Escape character is '^]'.

  lab04 http 10.244.0.55
HTTP/1.1 302 Found
Connection: Keep-Alive
Content-Length: 0
Content-Type: text/html; charset=UTF-8
Date: Mon, 10 Jun 2019 06:14:58 GMT
Keep-Alive: timeout=5, max=100
Location: http://10.244.0.55/wp-admin/setup-config.php
Server: Apache/2.4.25 (Debian)
X-Powered-By: PHP/7.3.6

可见两个容器已经在同一个Pod内启动,并且mysql的3306端口也是通的,wordpress的80也是OK的

进入wordpress设置界面进行配置

下一步

上图说了,缺数据库,来手工创建一个库

  lab04 kubectl get pods -o wide
NAME        READY   STATUS    RESTARTS   AGE     IP            NODE       NOMINATED NODE   READINESS GATES
wordpress   2/2     Running   0          5m40s   10.244.0.57   worker01   <none>           <none>
  lab04 docker run -it --network host --rm mysql mysql -h10.244.0.57 -uroot -p
Enter password: 
Welcome to the MySQL monitor.  Commands end with ; or \g.
Your MySQL connection id is 3
Server version: 5.7.26 MySQL Community Server (GPL)

Copyright (c) 2000, 2019, Oracle and/or its affiliates. All rights reserved.

Oracle is a registered trademark of Oracle Corporation and/or its
affiliates. Other names may be trademarks of their respective
owners.

Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.

mysql> create database wordpress;
Query OK, 1 row affected (0.00 sec)

再来一次,成功了!

通过标签过滤,查看下本次实验我们创建的所有资源:

  lab04 git:(master) kubectl get all -l app=wordpress
NAME            READY   STATUS    RESTARTS   AGE
pod/wordpress   2/2     Running   0          29m

NAME                    TYPE       CLUSTER-IP    EXTERNAL-IP   PORT(S)        AGE
service/wordpress-svc   NodePort   10.98.40.11   <none>        80:30466/TCP   67m

总结

我们通过定义Pod,将两个容器定义在一个Pod当中,启动了wordpress+mysql的一个Pod实例,并使用NodePort类型的Service对wordpress进行了设置及访问,成功实践了一Pod多容器的使用方式。
或许你已经想到了当前这个实验结果的问题:

  • 1,mysql的数据是状态化数据需要保存
  • 2,直接定义的Pod是无法进行修改,扩容的,只能删除重建
    这些问题,我们后面使用到的StatefulSet及Deployment等可以解决。
相关实践学习
深入解析Docker容器化技术
Docker是一个开源的应用容器引擎,让开发者可以打包他们的应用以及依赖包到一个可移植的容器中,然后发布到任何流行的Linux机器上,也可以实现虚拟化,容器是完全使用沙箱机制,相互之间不会有任何接口。Docker是世界领先的软件容器平台。开发人员利用Docker可以消除协作编码时“在我的机器上可正常工作”的问题。运维人员利用Docker可以在隔离容器中并行运行和管理应用,获得更好的计算密度。企业利用Docker可以构建敏捷的软件交付管道,以更快的速度、更高的安全性和可靠的信誉为Linux和Windows Server应用发布新功能。 在本套课程中,我们将全面的讲解Docker技术栈,从环境安装到容器、镜像操作以及生产环境如何部署开发的微服务应用。本课程由黑马程序员提供。 &nbsp; &nbsp; 相关的阿里云产品:容器服务 ACK 容器服务 Kubernetes 版(简称 ACK)提供高性能可伸缩的容器应用管理能力,支持企业级容器化应用的全生命周期管理。整合阿里云虚拟化、存储、网络和安全能力,打造云端最佳容器化应用运行环境。 了解产品详情: https://www.aliyun.com/product/kubernetes
目录
相关文章
|
8月前
|
Kubernetes Docker 容器
Kubernetes与Docker参数对照:理解Pod中的command、args与Dockerfile中的CMD、ENTRYPOINT。
需要明确的是,理解这些都需要对Docker和Kubernetes有一定深度的理解,才能把握二者的区别和联系。虽然它们都是容器技术的二个重要组成部分,但各有其特性和适用场景,理解它们的本质和工作方式,才能更好的使用这些工具,将各自的优点整合到生产环境中,实现软件的快速开发和部署。
288 25
|
12月前
|
Prometheus Kubernetes 监控
深入探索Kubernetes中的Pod自动扩展(Horizontal Pod Autoscaler, HPA)
深入探索Kubernetes中的Pod自动扩展(Horizontal Pod Autoscaler, HPA)
|
8月前
|
Kubernetes Shell Windows
【Azure K8S | AKS】在AKS的节点中抓取目标POD的网络包方法分享
在AKS中遇到复杂网络问题时,可通过以下步骤进入特定POD抓取网络包进行分析:1. 使用`kubectl get pods`确认Pod所在Node;2. 通过`kubectl node-shell`登录Node;3. 使用`crictl ps`找到Pod的Container ID;4. 获取PID并使用`nsenter`进入Pod的网络空间;5. 在`/var/tmp`目录下使用`tcpdump`抓包。完成后按Ctrl+C停止抓包。
282 12
|
存储 Kubernetes Docker
【赵渝强老师】Kubernetes中Pod的基础容器
Pod 是 Kubernetes 中的基本单位,代表集群上运行的一个进程。它由一个或多个容器组成,包括业务容器、基础容器、初始化容器和临时容器。基础容器负责维护 Pod 的网络空间,对用户透明。文中附有图片和视频讲解,详细介绍了 Pod 的组成结构及其在网络配置中的作用。
206 1
【赵渝强老师】Kubernetes中Pod的基础容器
|
运维 Kubernetes Shell
【赵渝强老师】K8s中Pod的临时容器
Pod 是 Kubernetes 中的基本调度单位,由一个或多个容器组成,包括业务容器、基础容器、初始化容器和临时容器。临时容器用于故障排查和性能诊断,不适用于构建应用程序。当 Pod 中的容器异常退出或容器镜像不包含调试工具时,临时容器非常有用。文中通过示例展示了如何使用 `kubectl debug` 命令创建临时容器进行调试。
215 1
|
Kubernetes 调度 容器
【赵渝强老师】K8s中Pod中的业务容器
Pod 是 Kubernetes 中的基本调度单元,由一个或多个容器组成。除了业务容器,Pod 还包括基础容器、初始化容器和临时容器。本文通过示例介绍如何创建包含业务容器的 Pod,并提供了一个视频讲解。示例中创建了一个名为 &quot;busybox-container&quot; 的业务容器,并使用 `kubectl create -f firstpod.yaml` 命令部署 Pod。
170 1
|
Kubernetes 容器 Perl
【赵渝强老师】K8s中Pod中的初始化容器
Kubernetes的Pod包含业务容器、基础容器、初始化容器和临时容器。初始化容器在业务容器前运行,用于执行必要的初始化任务。本文介绍了初始化容器的作用、配置方法及优势,并提供了一个示例。
221 1
|
存储 Kubernetes 调度
深入理解Kubernetes中的Pod与Container
深入理解Kubernetes中的Pod与Container
747 0
|
Kubernetes Java 调度
Kubernetes中的Pod垃圾回收策略是什么
Kubernetes中的Pod垃圾回收策略是什么
|
存储 Kubernetes 调度
深度解析Kubernetes中的Pod生命周期管理
深度解析Kubernetes中的Pod生命周期管理

推荐镜像

更多