K8S自己动手系列 - 2.1 - Pod
说在最前
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等可以解决。
低调大师中文资讯倾力打造互联网数据资讯、行业资源、电子商务、移动互联网、网络营销平台。
持续更新报道IT业界、互联网、市场资讯、驱动更新,是最及时权威的产业资讯及硬件资讯报道平台。
转载内容版权归作者及来源网站所有,本站原创内容转载请注明来源。
- 上一篇
K8S自己动手系列 - 1.3 - Taint & Affinity
Taint please refer https://kubernetes.io/docs/concepts/configuration/taint-and-toleration/三种taint: NoSchedule PreferNoSchedule NoExecute 为节点打Taint ~ kubectl taint node worker02 role=nginx:NoSchedule node/worker02 tainted ~ kubectl describe node worker02 Name: worker02 ... Taints: role=nginx:NoSchedule ~ kubectl get pod -o wide NAME READY STATUS RESTARTS AGE IP NODE NOMINATED NODE READINESS GATES nginx-7cffb9df96-748j6 1/1 Running 0 5m21s 10.244.0.23 worker01 <none> <none> nginx-7cffb...
- 下一篇
云存储网关商业化发布
产品介绍: 通过云存储网关,客户在无需改变应用程序接口的情况下,可以直接使用NFS/SMB或iSCSI协议访问OSS存储空间 适用客户: 典型客户群体: 生命科学,影视渲染,医疗,制造业 视频监控,中小企业,工作室,分支机构等。 应用场景 : 数据备份和归档上云, 存储空间云上弹性扩容, 数据共享和分发,企业数据二级存储 发布功能: 云存储网关实现了云端对象存储协议(OSS)与文件存储协议(NFS/SMB)或者块存储协议(iSCSI)之间的转换,帮助客户在无需改变现有应用程序接口和使用习惯的情况下直接使用OSS存储空间,实现用户数据与阿里云OSS的无缝对接。云存储网关可部署在客户数据中心虚拟机或者阿里云上。 付费方式: 云上部署的云存储网关按照网关实例收费,包含网关软件和部署网关所需的计算资源。 线下部署的云存储网关,阿里云
相关文章
文章评论
共有0条评论来说两句吧...
文章二维码
点击排行
-
Docker使用Oracle官方镜像安装(12C,18C,19C)
- Springboot2将连接池hikari替换为druid,体验最强大的数据库连接池
- CentOS8编译安装MySQL8.0.19
- Docker快速安装Oracle11G,搭建oracle11g学习环境
- SpringBoot2配置默认Tomcat设置,开启更多高级功能
- MySQL8.0.19开启GTID主从同步CentOS8
- CentOS7,8上快速安装Gitea,搭建Git服务器
- Jdk安装(Linux,MacOS,Windows),包含三大操作系统的最全安装
- SpringBoot2编写第一个Controller,响应你的http请求并返回结果
推荐阅读
最新文章
- SpringBoot2整合Thymeleaf,官方推荐html解决方案
- CentOS关闭SELinux安全模块
- CentOS8编译安装MySQL8.0.19
- CentOS7设置SWAP分区,小内存服务器的救世主
- 设置Eclipse缩进为4个空格,增强代码规范
- CentOS8安装MyCat,轻松搞定数据库的读写分离、垂直分库、水平分库
- CentOS7编译安装Gcc9.2.0,解决mysql等软件编译问题
- SpringBoot2编写第一个Controller,响应你的http请求并返回结果
- Springboot2将连接池hikari替换为druid,体验最强大的数据库连接池
- CentOS7编译安装Cmake3.16.3,解决mysql等软件编译问题