Comfigmap:存储数据
Date:
Key:value
挂载的方式,把配置信息传给容器
生产当中的yml文件很长:
有deployment
容器的探针
资源限制
Configmap
存储卷
Service
Ingress
K8s的对外服务,ingress
Service作用体现在两个方面:
- 集群内部:不断跟踪pod的变化,更新endpoint中的pod对象,基于pod的IP地址不断变化的一种服务发现机制
- 集群外部:类似于负载均衡器,把流量IP+端口,不涉及url(http https),把请求转发到pod当中
Service:
NodePort:容器端口---service端口----NodePort,设定了nodePort,每个节点都会有一个端口被打开,30000-32767
IP+端口:节点IP+30000-32767,实现负载均衡
Loadbalancer:云平台上的一种service机制,云平台一个负载均衡IP地址
Extrenal:域名映射
Ingress:基于域名进行映射,把url(http,https)请求转发到service,再由service把请求转发到每一个pod
Ingress只要一个或者少量的公网IP或者LB,可以把多个http请求暴露到网外,七层反向代理
Service的service。是一组基于域名和url路径,把一个或者多个请求转发到service的规则
先是七层代理---四层代理-----pod
Ingress service nginx
Ingress的组成:
Ingress是一个api对象,通过yaml文件来进行配置,ingress的作用是定义请求如何转发到service的规则,配置模板
Ingress通过http和https暴露集群内部service,给service提供一个外部的URL,负载均衡,ssl/tsl(https)的能力,实现了一个基于域名的负载均衡
Ingress-controller: 具体的实现反向代理和负载均衡的程序,对ingress定义的规则进行解析,根据ingress的配置规则进行请求的转发,Ingress-controller不是k8s自带的组件功能,ingress-controller一个统称
例如nginx ingress controller,traefik都是Ingress-controller,他们都是开源的
Ingress资源的定义项:
- 定义外部流量的规则
- 定义服务的暴露方式,主机名,访问路径和其他的选择
- 负载均衡(ingress-controller)
ingress-controller的运行方式是pod方式运行在集群当中
Nginx-ingress-controller:
如何下载:
wget https://gitee.com/mirrors/ingress-nginx/raw/nginx-0.30.0/deploy/static/mandatory.yaml
data:image/s3,"s3://crabby-images/10b1c/10b1c313817713860917f4130655d9f27ecf65b9" alt=""
Ingress暴露服务的方式:
-
方式一:deployment+LoadBalance模式,ingress部署在公有云,ingress配置文件里面会有一个type,type:LoadBalancer. 公有云平台会为个Loadbalance的service创建一个负载均衡器,绑定一个公网地址。通过域名指向这个公网地址就可以实现集群对外暴露
-
方式二:daemonset+hostnetwork+nodeSelector模式:
解析:
Daemonset:在每个节点都会创建一个pod
Hostnework:pod共享节点主机的网络命名空间,容器内直接使用节点主机的IP+端口。Pod当中的容器可以直接访问网络资源
nodeSelector:根据标签来选择部署的节点,Nginx-ingress-controller部署的节点
缺点:直接利用了节点主机的网络和端口,一个node只能部署一个ingress-controller pod比价适合大并发的生产环境,性能是最好的
核心图:
data:image/s3,"s3://crabby-images/c57ad/c57adf42d57e0eb0d295bcba41a1055fad8e0bc5" alt=""
- 方式三:deployment+NodePort 方式
实验演示方式一实现:
1、下载nginx ingress contoller控制器
wget https://gitee.com/mirrors/ingress-nginx/raw/nginx-0.30.0/deploy/static/mandatory.yaml
data:image/s3,"s3://crabby-images/f3606/f3606987b67695a74c2d503b47a4cc6840891128" alt=""
修改一下配置文件:
data:image/s3,"s3://crabby-images/bc417/bc417ad2a2400be7e1f7a3e73996be67e5e6648d" alt=""
data:image/s3,"s3://crabby-images/0b8b8/0b8b8c5dd5bf0b27388362dcf8b1ea9cf149e827" alt=""
data:image/s3,"s3://crabby-images/85fdb/85fdbcb03225f3ea6587a5b4612835c86d3095c6" alt=""
创建标签:
data:image/s3,"s3://crabby-images/dd492/dd492025b19b9e9c54e5664e8f2dd5c6da08201d" alt=""
kubectl get pod -n ingress-nginx -o wide
data:image/s3,"s3://crabby-images/904ce/904cef6b8606cd3b040867b96a7b819bab8ae8a4" alt=""
上传控制器镜像,也就是nginx-ingress-controller的镜像:拖入每个节点
tar -xf ingree.contro-0.30.0.tar.gz
docker load -i ingree.contro-0.30.0.tar
data:image/s3,"s3://crabby-images/1ca8f/1ca8f128878d75c3db703f551c004f082694cb98" alt=""
在controller控制器创建的pod的节点上查看端口
netstat -antp|grep nginx
data:image/s3,"s3://crabby-images/0db09/0db094b7b7f9ee10a09f7825cc7808fdfbbc0fb6" alt=""
tcp 0 0 0.0.0.0:80 0.0.0.0:* LISTEN 27897/nginx: master
tcp 0 0 0.0.0.0:8181 0.0.0.0:* LISTEN 27897/nginx: master
tcp 0 0 0.0.0.0:443 0.0.0.0:* LISTEN 27897/nginx: master
解析:8081端口,nginx-controller默认配置的一个bachend,反向代理的端口
所有请求当中,只要是不符合ingress配置的请求会转发到8081,相当于error的界面
- 定义yml脚本,创建pvc、pod、service、ingress
data:image/s3,"s3://crabby-images/4a5c3/4a5c351ced867cf87eade862996dbd5a56c6200b" alt=""
data:image/s3,"s3://crabby-images/5cc21/5cc21d3c80741c4f5c7f4c3f0b5334e9421c1769" alt=""
data:image/s3,"s3://crabby-images/3ae85/3ae8503ea2dc09f2ef5bf0fb2c2d2acc4d788bac" alt=""
data:image/s3,"s3://crabby-images/0de7e/0de7e143fb1e9447e345e2e543df5c3027fd41b3" alt=""
data:image/s3,"s3://crabby-images/fafc7/fafc7b95c3c18105c29aae121854a593190acd0a" alt=""
data:image/s3,"s3://crabby-images/c997b/c997b3a17f9b1d3aeba36c3708ec68e5bb0ba3b5" alt=""
kubectl get pod -o wide
data:image/s3,"s3://crabby-images/a0d0e/a0d0e0f4af5d97f80d30367557fb57f8a24b5814" alt=""
映射
vim /etc/hosts
data:image/s3,"s3://crabby-images/62f88/62f88e1989d7641f5de81fbdbce3b95b73b28319" alt=""
测试访问
data:image/s3,"s3://crabby-images/9e377/9e37769b4ab0fcbacb7b7f5e4c1476256acefc9d" alt=""
data:image/s3,"s3://crabby-images/7b96f/7b96f90958cec523c0b83bdc3edcd80039cee0d0" alt=""
负载均衡已经实现(分别查看三个容器的日志)
data:image/s3,"s3://crabby-images/463df/463dffae1aa6e8ed1eca85f85fa83df989be661f" alt=""
data:image/s3,"s3://crabby-images/16d22/16d2201d3463a50ae389b26742003058d3df42f1" alt=""
data:image/s3,"s3://crabby-images/f383a/f383ab625a4df99ed01df7a42f2cccdd7a15968d" alt=""
结论:endpointIP地址变化
data:image/s3,"s3://crabby-images/11451/11451d8c468ffaa4cc1718125d3b168504424a70" alt=""
如何实现第二种方式:
如何实现deployment+nodePort (常见模式)
data:image/s3,"s3://crabby-images/6cff2/6cff2261d2a6e0fc78253c184b832163b50c534b" alt=""
将之前的全部删除
data:image/s3,"s3://crabby-images/07f32/07f3220615a089197b565ae1df78ebb5eee4b180" alt=""
下载nginx ingress contoller控制器
wget https://gitee.com/mirrors/ingress-nginx/raw/nginx-0.30.0/deploy/static/mandatory.yaml
data:image/s3,"s3://crabby-images/ee80c/ee80c5f1f470501771e6e92c59288a0d037e3283" alt=""
data:image/s3,"s3://crabby-images/bb080/bb0804567555eeb515e425647cb07febd3c95294" alt=""
将原来的基于daemonset删除ingress删除
data:image/s3,"s3://crabby-images/34e6f/34e6fb517c76b0c01e41825974dbc70e689d28b5" alt=""
data:image/s3,"s3://crabby-images/aaa34/aaa34ac3db860d91ef70cb2d835bafd034c9cc08" alt=""
data:image/s3,"s3://crabby-images/43b11/43b11b16281031650bc905d0095bc385ff4533e7" alt=""
下载service-nodeport控制器
data:image/s3,"s3://crabby-images/03fce/03fcee23d54f3c79c31311d0461721f07b873093" alt=""
data:image/s3,"s3://crabby-images/3d7f4/3d7f4879f3af22af3367fc7b005aa15aafd19d4a" alt=""
定义yml脚本,创建pvc、pod、service、ingress
data:image/s3,"s3://crabby-images/d480b/d480bbff1e62063808f09df25ada0846b98ea297" alt=""
data:image/s3,"s3://crabby-images/3b6ee/3b6eef2ab7a9ab08f4e77264ff18defa7f48af5e" alt=""
data:image/s3,"s3://crabby-images/f93db/f93db82151f065063dfbb86a63f8c458e94e1300" alt=""
data:image/s3,"s3://crabby-images/dcc4d/dcc4d1189ca9a72a566d29ffa481ce16d3e489b3" alt=""
data:image/s3,"s3://crabby-images/28abe/28abeb2e6d431d33f94fda2343405adfd7acd1f6" alt=""
做映射,端口可以随便写
data:image/s3,"s3://crabby-images/f35bf/f35bf689fd1fcd071c9277f0257ca1bee82b355b" alt=""
data:image/s3,"s3://crabby-images/1f124/1f1242e61c7784d99ea10b28956fdae577ef737f" alt=""
data:image/s3,"s3://crabby-images/6bc99/6bc996976c0ff3fce97ae0c65617b0e606eef297" alt=""
结构图:
解析图:
data:image/s3,"s3://crabby-images/2424c/2424cad027aa81a1c3b643ed7f597c8a3ac9e334" alt=""
data:image/s3,"s3://crabby-images/2f98c/2f98c962e1454610acf250d0d4cef3ec8c8d384b" alt=""
data:image/s3,"s3://crabby-images/0e739/0e739cce80d1070a662738309a522d326d9a8f50" alt=""
三种模式:
Nginx-ingress-controller
Host--->ingress的配置找到pod----controller---请求发送到pod
NodePort----controller---ingress-----service----pod
NodePort暴露端口的方式是最简单的方法,NodePort多了一层NAT,(地址转换)
并发量大的对性能会有一定影响,内部会有NodePort
虚拟主机的方式实现http代理:
创建多个pod、service
pod1、service1
data:image/s3,"s3://crabby-images/ce546/ce546f75971f7eae0db5240c9ef2c9e8620651c8" alt=""
pod2、service2
data:image/s3,"s3://crabby-images/aac01/aac0185e88aa7ba5d8876f5e30c83161b1626b4e" alt=""
配置ingress
data:image/s3,"s3://crabby-images/69950/6995048b670d7b511cdc789be5547fdaad428af6" alt=""
data:image/s3,"s3://crabby-images/151f6/151f6229d9010777bfd6510c4dac0f558aaaba13" alt=""
data:image/s3,"s3://crabby-images/cf199/cf1995b6d26ed6a286330d6bc29d6108427d99a0" alt=""
data:image/s3,"s3://crabby-images/ac7ec/ac7ec6d69397b1a8548f0d77ef9b68ab61dfc178" alt=""
做映射:
data:image/s3,"s3://crabby-images/fde01/fde01734551e44b4165e2c31afc265dc6380f2f2" alt=""
data:image/s3,"s3://crabby-images/3be70/3be7086a2b654b84e0f8016b2cb79a8d36992dc2" alt=""
data:image/s3,"s3://crabby-images/37e91/37e91741af719e31307b654479ab21f7bb7cdc29" alt=""
data:image/s3,"s3://crabby-images/a1b93/a1b934699b532b75ab40e6beb0e960154b2c078d" alt=""
总结:
Ingress的核心组件----nginx-ingress-controller和traefik
他们都是开源的ingress--controller
三种方式:
Deployment+loadbalancer需要云平台提供一个负载均衡的公网地址,公有云上做(需要钱)
Daemonset+hostnetwork+nodeselector指定节点部署controller,缺点就是和宿主机共享网络,只能是一个controller的pod
Deployment+NodePort最常见,最简单的方式,其中一个nodeport端口,所有的ingress的请求都会转发到NodePort,然后service把流量转发到pod,一个nginx的NodePort,实现访问多个虚拟主机
和nginx类型:
一个端口可以访问多个
例如:80端口,可以访问www.test1.com www.test2.com