kubernetes ingress粗浅学习

Service对集群之外暴露服务的主要方式有两种:NotePort和LoadBalancer,但是这两种方式,都有一定的缺点:

  • NodePort方式的缺点是会占用很多集群机器的端口,那么当集群服务变多的时候,这个缺点就愈发明显。

  • LB方式的缺点是每个service需要一个LB,浪费、麻烦,并且需要kubernetes之外设备的支持。

基于这种现状,kubernetes提供了Ingress资源对象,Ingress只需要一个NodePort或者一个LB就可以满足暴露多个Service的需求。工作机制大致如下图表示:

实际上,Ingress相当于一个7层的负载均衡器,是kubernetes对反向代理的一个抽象,它的工作原理类似于Nginx,可以理解成在Ingress里建立诸多映射规则,Ingress Controller通过监听这些配置规则并转化成Nginx的反向代理配置 , 然后对外部提供服务。在这里有两个核心概念:

  • ingress:kubernetes中的一个对象,作用是定义请求如何转发到service的规则

  • ingress controller:具体实现反向代理及负载均衡的程序,对ingress定义的规则进行解析,根据配置的规则来实现请求转发,实现方式有很多,比如Nginx, Contour, Haproxy等等

Ingress(以Nginx为例)的工作原理如下:

  • 用户编写Ingress规则,说明哪个域名对应kubernetes集群中的哪个Service

  • Ingress控制器动态感知 Ingress服务规则的变化,然后生成一段对应的Nginx反向代理配置

  • Ingress控制器会将生成的Nginx配置写入到一个运行着的Nginx服务中的pod,并动态更新

  • 到此为止,其实真正在工作的就是一个Nginx了,内部配置了用户定义的请求转发规则

!!!每个docker版本对应ingress的可用版本是不一样的,下载之前一定要确定版本!!!

下面开始做ingress实验

下载好所需环境yum install -y lrzsz

创建本地ingress镜像源

分发给node节点

for i in node{1,2}; do scp ingress-webhook.tar k8s-$i:/root;done

for i in node{1,2}; do scp ingress.tar k8s-$i:/root;done

在每个节点拉取ingress镜像文件创建容器

docker load -i ingress.tar

docker load -i ingress-webhook.tar

创建一个目录 mkdir ingress

拉入压缩包并解压unzip ingress-nginx-controller-v1.12.0.zip

进入官方提供的、一键安装 Nginx Ingress Controller 的目录:

cd ingress-nginx-controller-v1.12.0/deploy/static/provider/cloud

需要更改文件配置内容,先查看内容所在文件位置:cat deploy.yaml | grep -n image

进入vim deploy.yaml文件,删除@和之后的内容

创建容器kubectl create -f deploy.yaml

查看 ingress-nginx 命名空间里的 Pod 状态:kubectl -n ingress-nginx get po

修改 Nginx 网关的对外端口(Service)配置,LoadBalancer改为NotePort

kubectl -n ingress-nginx edit svc ingress-nginx-controller

就可以用端口访问

创建文件vim nginx-svc.yml ,里面写pod设置和nginx设置

创建ingress规则vim nginx-ingress.yml

kubectl create -f nginx-ingress.yml

确认端口号:kubectl -n ingress-nginx get svc

查看在哪个node上运行:kubectl -n ingress-nginx get pod -o wide

要想访问,先在要访问的服务器上vim /etc/hosts ,在运行的node或IP后加入访问网址

相关推荐
晓梦林1 小时前
Loooower靶场学习笔记
笔记·学习·安全·web安全
海参崴-2 小时前
手写红黑树全流程学习总结
学习·算法
凤舞飘伶2 小时前
windows安装docker-desk
windows·docker·容器
我命由我123452 小时前
前端开发概念 - 无障碍树
javascript·css·笔记·学习·html·html5·js
运维全栈笔记2 小时前
Docker一键部署Immich:自建私有云相册,照片视频备份无忧
linux·服务器·网络·docker·容器
绿豆人2 小时前
Cache缓存项目学习4
windows·学习·缓存
Bechamz2 小时前
大数据开发学习Day29
大数据·学习
IT大白鼠2 小时前
AIGC+教育:个性化学习、AI助教、内容生产,教育行业的变革路径
人工智能·学习·aigc
@杰克成2 小时前
Java学习24
java·学习·idea