首先附上K8S版本及Ingress版本对照
NotePort:该方式的缺点是会占用很多集群机器的端口,当集群服务变多时,这个缺点就愈发的明显(srevice变多,需要的端口就需要多)
LoadBalancer:该方式的缺点是每个service都需要一个外部负载均衡设备的支持才可以
基于这种现状,k8s提供了ingress资源对象。
ingress只需要一个NodePort/一个负载均衡设备就可以满足暴露多个service的需求
实际上Ingress相当于一个7层的负载均衡器(在生产环境中常用的Ingress有Treafik、Nginx、HAProxy、Istio等),是k8s对反向代理的一个抽象,它的工作原理类似于Nginx,可以理解成Ingress里建立诸多映射规则,Ingress Colltroller通过监听这些配置规则并转化成Nginx的反向代理配置,然后对外部提供服务,在这里有两个核心理念:
根据配置的规则来实现请求转发,实现方式有很多,比如Nginx,Contour,Haproxy等等
ingress-controller通过和 kubernetes APIServer 交互,动态的去感知集群中ingress规则变化;
然后读取它,按照自定义的规则,规则就是写明了哪个域名对应哪个service,生成一段nginx配置;
再写到nginx-ingress-controller的pod里,这个ingress-controller的pod里运行着一个Nginx服务,控制器会把生成的 nginx配置写入 /etc/nginx.conf文件中;
然后reload一下使配置生效。以此达到域名区分配置和动态更新的作用。
我这里的K8S版本为1.23.5对应的安装ingress-nginx-1.6.4;
下载对应部署文件deploy.yaml(这一步需要魔法,没有的可以从下链接提取)
同时为了方便后续http和https的分辨,固定端口为31080和31443
未修改版本
https://pan.baidu.com/s/1FJ3ai_5YQYypKi72HhpGqg?pwd=weiy
提取码:weiy
已修改版本
https://pan.baidu.com/s/1CF5UJ8aQy-IDvpv9r2RYuQ?pwd=weiy
提取码:weiy
注意80对应的是HTTP端口,443对应的是HTTPS端口
部署文件上传后,需要注意切换为国内镜像地址(修改成国内可以下载的相同镜像)
具体修改如下:
image: registry.k8s.io/ingress-nginx/kube-webhook-certgen:v20220916-gd32f8c343@sha256:39c5b2e3310dc4264d638ad28d9d1d96c4cbb2b2dcfb52368fe4e3c63f61e10f
将其改为:
dyrnq/kube-webhook-certgen:v20220916-gd32f8c343
image: registry.k8s.io/ingress-nginx/controller:v1.6.4@sha256:15be4666c53052484dd2992efacf2f50ea77a78ae8aa21ccd91af6baaa7ea22f
将其修改为:
registry.cn-hangzhou.aliyuncs.com/google_containers/nginx-ingress-controller:v1.6.4
[root@master ~]# mkdir /ingress-controller
[root@master ~]# cd /ingress-controller
[root@master ~]# ls
[root@master ingress-controller]# kubectl apply -f ./
正常为created,我先前已经apply
[root@master ingress-controller]# kubectl get po -n ingress-nginx
[root@master ingress-controller]# kubectl get svc -n ingress-nginx
[root@k8s-master ~]# cat>tomcat-nginx.yml <
这里我固定了调度的node,为node2
[root@master ~]# kubectl create -f tomcat-nginx.yml
[root@master ~]# kubectl get svc -n dev
[root@master ~]# kubectl get po -n dev
通过ingress代理http服务,创建ingress-http.yml
[root@master ~]# vim ingress-http.yml
apiVersion: networking.k8s.io/v1
kind: Ingress
metadata:
name: ingress-http
namespace: dev
spec:
ingressClassName: nginx
rules:
- host: www.nginx.com
http: #访问的方式是以http的形式
paths:
- backend:
service:
name: nginx-service #用户在访问域名的时候,会反向代理给service,也就是后面的pod(service是通过标签去代理的)
port:
number: 80
path: /
pathType: ImplementationSpecific
- host: www.tomcat.com
http:
paths:
- backend:
service:
name: tomcat-service
port:
number: 80
path: /
pathType: ImplementationSpecific
[root@master ~]# kubectl create -f ingress-http.yml
[root@master ~]# kubectl get ing ingress-http -n dev
[root@master ~]# kubectl describe ing ingress-http -n dev
浏览器访问由于域名无法正常解析,需要在windows内进行解析
C:\Windows\System32\drivers\etc
添加解析: