当前位置: 代码网 > it编程>数据库>Mysql > k8s学习--ingress详细解释与应用(nginx ingress controller))

k8s学习--ingress详细解释与应用(nginx ingress controller))

2024年08月02日 Mysql 我要评论
Ingress 是 Kubernetes 中用于管理集群内服务暴露的 API 资源。它提供了 HTTP 和 HTTPS 路由功能,使外部流量能够访问集群内部的服务。通过定义 Ingress 资源,可以控制哪些外部请求能够访问集群中的哪些服务,以及如何路由这些请求。


lngress简介

什么是 ingress

ingress 是 kubernetes 中用于管理集群内服务暴露的 api 资源。它提供了 http 和 https 路由功能,使外部流量能够访问集群内部的服务。通过定义 ingress 资源,可以控制哪些外部请求能够访问集群中的哪些服务,以及如何路由这些请求。

ingress 的用途

统一入口控制
ingress 提供了一个统一的入口点,用于管理多个服务的访问和流量控制。

http/https 路由
通过 ingress,可以配置基于主机名和路径的路由规则,将外部请求定向到集群内部的服务。

ssl 终止
ingress 可以配置 ssl 证书,用于加密和解密外部流量,从而确保数据传输的安全性。

负载均衡
通过 ingress 控制器,可以实现对多实例服务的负载均衡,将请求分发到多个后端实例。

ingress 的工作原理

ingress 的工作原理涉及以下两个关键组件:

ingress 资源
用户定义的 kubernetes 资源,描述了主机名、路径和后端服务之间的映射关系。

ingress 控制器
实现 ingress 规则的实际组件。常见的 ingress 控制器包括 nginx、traefik 和 haproxy 等。控制器监控 ingress 资源的变化,并相应地配置其代理服务器,以实现路由和流量管理。

ingress 的工作流程

定义 ingress 资源
用户创建 ingress 资源,定义了主机名、路径和后端服务的映射。

ingress 控制器监控
ingress 控制器不断监控 ingress 资源的变化。
配置代理服务器:
根据 ingress 资源的定义,ingress 控制器配置其代理服务器(如 nginx)以匹配请求。

处理请求
当外部请求到达集群时,ingress 控制器的代理服务器根据 ingress 规则进行路由,将请求转发到相应的服务。

ingress 的应用场景

多服务管理
适用于需要管理多个服务的环境,通过 ingress 实现统一的入口控制。

基于域名的路由
在同一个集群中运行多个应用,通过不同的域名或子域名进行访问。

基于路径的路由
根据请求路径将流量路由到不同的服务,例如 /api 路径指向一个微服务,/web 路径指向另一个微服务。

ssl 终止
需要使用 https 加密流量的场景,通过 ingress 配置 ssl 证书进行终止。

负载均衡
在多实例服务间进行负载均衡,以提高服务的可用性和扩展性。

应用

实验环境

虚拟机

ip主机名cpu内存硬盘
192.168.10.11master012cpu双核4g100g
192.168.10.12worker012cpu双核4g100g
192.168.10.13worker022cpu双核4g100g
192.168.10.16vm61cpu1核1g20g

版本 centos7.9
已部署k8s-1.27
vm6 无需配置,测试使用

部署nginx ingress controller

1.安装metallb

具体步骤详情作者上篇博客
链接: metallb负载均衡器
这里不再过多描述

2.nginx ingress controller部署

下载并修改配置文件 需要vpn

curl -k https://raw.githubusercontent.com/kubernetes/ingress-nginx/main/deploy/static/provider/baremetal/deploy.yaml  -o deploy.yaml

修改文件

vim deploy.yaml

修改此行 type: nodeport
为 type: loadbalancer

修改前
在这里插入图片描述
修改后
在这里插入图片描述

创建

kubectl apply -f deploy.yaml

稍等几分钟后查看 需要vpn,没有的话查看信息时会显示连接不到镜像仓库

kubectl -n ingress-nginx get pod

可以看到已经成功运行了
在这里插入图片描述

3.ingress 对象应用案例(基于名称的负载均衡)

ingress-http案例:基于名称的负载均衡

(1) 创建deployment控制器类型应用
vim nginx.yaml
apiversion: apps/v1
kind: deployment
metadata:
  name: nginx
  namespace: ingress-nginx
spec:
  replicas: 2
  selector:
    matchlabels:
      app: nginx
  template:
    metadata:
      labels:
        app: nginx
    spec:
      containers:
      - name: c1
        image: nginx:1.20
        imagepullpolicy: ifnotpresent

应用yaml

kubectl apply -f nginx.yaml

验证pod

kubectl get pods -n ingress-nginx

在这里插入图片描述

(2) 创建service
vim nginx-service.yaml
apiversion: v1
kind: service
metadata:
  name: nginx-service
  namespace: ingress-nginx
  labels:
    app: nginx
spec:
  ports:
  - port: 80
    targetport: 80
  selector:
app: nginx

应用yaml

vim nginx-service.yaml

查看service

kubectl get svc -n ingress-nginx

在这里插入图片描述
默认service类型是clusterip

(3) 创建ingress对象
vim ingress-nginx.yaml
apiversion: networking.k8s.io/v1
kind: ingress
metadata:
  name: ingress-nginx                    			#自定义ingress对象名称
  namespace: ingress-nginx
  annotations:									#注解,声明
    ingressclass.kubernetes.io/is-default-class: "true"		#ingress控制器由标记的class作为默认class
spec:
  ingressclassname: nginx							#此处标记出ingressclass为nginx
  rules:
  - host: www.test.com                   			# 自定义域名
    http:
      paths:
      - pathtype: prefix
        path: "/"
        backend:
          service:
            name: nginx-service     				# 对应上面创建的service名称
            port:
              number: 80

应用yaml

kubectl apply -f ingress-nginx.yaml

验证ingress对象

kubectl get ingress -n ingress-nginx

在这里插入图片描述

描述查看ingress信息

kubectl describe ingress ingress-nginx -n ingress-nginx

在这里插入图片描述

kubectl get pods -o wide -n ingress-nginx

在这里插入图片描述

可以看到两个pod的ip正好对应ingress域名对应的ip
确认nginx-ingress-controller的podip为192.168.10.240

(4) 模拟客户端访问

确认nginx-ingress-controller的podip, 下面命令查询的结果为192.168.10.240

kubectl get svc -n ingress-nginx | grep ingress

在这里插入图片描述
在集群之外任一主机中添加上述域名与ip地址解析(模拟公网dns)
这里是192.168.10.16

vim /etc/hosts
192.168.10.240 www.test.com

准备pod内容器运行的web主页
查看

kubectl get pods  -n ingress-nginx

在这里插入图片描述

进入容器添加html文件

kubectl -n ingress-nginx exec -it nginx-c9f79b6f4-9xdms -- bash
echo "ingress web1" > /usr/share/nginx/html/index.html
exit

第二个

kubectl -n ingress-nginx exec -it nginx-c9f79b6f4-jqwsx -- bash
echo "ingress web2" > /usr/share/nginx/html/index.html
exit

去集群外的主机上测试
在这里插入图片描述
注; 经过测试.1.24版本的k8s集群部署会出现错误
解决方法
链接: rek安装k8s后,ingress-nginx一直状态为containercreating

完成
如果对您有帮助可以关注一下

(0)

相关文章:

版权声明:本文内容由互联网用户贡献,该文观点仅代表作者本人。本站仅提供信息存储服务,不拥有所有权,不承担相关法律责任。 如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 2386932994@qq.com 举报,一经查实将立刻删除。

发表评论

验证码:
Copyright © 2017-2025  代码网 保留所有权利. 粤ICP备2024248653号
站长QQ:2386932994 | 联系邮箱:2386932994@qq.com