百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术资源 > 正文

kubernetes 采用 Ingress 发布服务

off999 2025-02-04 15:39 19 浏览 0 评论

我们要将kubernetes集群内的服务发布到集群外使用,之前使用的方法都是 NodePort、LoadBalancer的 Service,或者是给 Service 配置 ExternalIP,也可以通过 Pod 的 HostPort 进行配置。但是这些方式都存在一些问题,几乎都是通过节点端口的形式向外暴露服务的,了解 Service 的人应该知道,通过 Service 向外暴露端口,实际是在集群中的所有节点上监听同一个端口,如果 Service 非常多,那每个节点上开启的端口就会变得很多,这样维护起来很复杂,而且也非常不安全。

使用 Ingress 可以解决这个问题,除了 Ingress 自身的服务向外发布以外,其他服务都不需要直接向外发布。用 Ingress 接收所有的外部请求,然后按照域名配置转发给对应的服务。

Ingress 简介

Ingress 包含 3 个组件

  • 反向代理负载均衡器这个类似 Nginx、Apache ,在集群中可以使用 Deployment、DaemonSet 等控制器来部署反向代理负载均衡器。
  • Ingress 控制器作为一个监控器不停地与 API Server 进行交互,实时的感知后端 Service、Pod 等的变化情况,例如新增或者减少,得到这些变化信息后,Ingress 控制器再结合 Ingress 服务自动生成配置,然后更新反向代理负载均衡器并且刷新其配置,达到服务发现的作用。
  • Ingress 服务定义访问规则,加入某个域名对应某个 Service,或者某个域名下的子路径对应某个 Service,那么当这个域名的请求进来时,就把请求转发给对应的 Service。根据这个规则,Ingress 控制器会将访问的规则动态写入负载均衡器的配置中,从而实现整体的服务发现和负载均衡。

Ingress 控制器的种类有很多种,但是在基本使用层面几乎没有差别,下面我们使用 Ingress-Nginx 控制器来展示一下 Ingress 的基本使用。

创建 Ingress-Nginx 控制器

下载官方部署文件 https://github.com/kubernetes/ingress-nginx

选择Tags对应的版本,我这里选择最新的,这个要看 kubernetes 集群的版本,如果版本比较低,有些 API 是不存在的,所以不一定要最新的版本,根据情况下载即可。下载好部署文件https://github.com/kubernetes/ingress-nginx/blob/nginx-0.30.0/deploy/static/mandatory.yaml,需要做一些简单的修改,在 Deployment 服务中指定网络方式为 hostNetwork: true,这样就可以在集群外部访问 Ingress 服务。

执行部署:

kubectl apply -f mandatory.yaml

测试 Ingress 服务

  • 创建两个服务 Nginx/Httpd
apiVersion: apps/v1
kind: Deployment
metadata:
  name: nginx
spec:
  replicas: 1
  selector:
    matchLabels:
      example: nginx
  template:
    metadata:
      labels:
        example: nginx
    spec:
      containers:
      - name: nginx
        image: nginx:latest
        ports:
        - containerPort: 80
---
apiVersion: v1
kind: Service
metadata:
  name: nginx
spec:
  selector:
    example: nginx
  ports:
    - protocol: TCP
      port: 80
      targetPort: 80
---
apiVersion: apps/v1
kind: Deployment
metadata:
  name: httpd
spec:
  replicas: 1
  selector:
    matchLabels:
      example: httpd
  template:
    metadata:
      labels:
        example: httpd
    spec:
      containers:
      - name: httpd
			  image: httpd:latest
        ports:
        - containerPort: 80
---
apiVersion: v1
kind: Service
metadata:
  name: httpd
spec:
  selector:
    example: httpd
  ports:
    - protocol: TCP
      port: 80
      targetPort: 80

执行创建命令:kubectl apply -f service.yml 测试一下服务是否可以正常访问

kubect get all

在解决节点的任意机器上访问服务:

curl 10.111.194.232
curl 10.109.202.249

创建 Ingress

基于多域名配置

apiVersion: extensions/v1beta1
kind: Ingress
metadata:
  name: webservice
  annotations:
    Kubernetes.io/ingress.class: "nginx"
spec:
  rules:
  - host: www.httpd.com
    http:
      paths:
      - path: /
        backend:
          serviceName: httpd
          servicePort: 80
  - host: www.nginx.com
    http:
      paths:
      - path: /
        backend:
          serviceName: nginx
          servicePort: 80

执行创建命令:kubectl apply -f ingress.yml查询创建的 Ingress 信息:kubectl get ingress

可以看到 HOSTS 中显示的域名信息

  • 查看 Ingress-Nginx pod 负载均衡信息
kubectl get po -n ingress-nginx
# 进入 nginx-ingress-controller Pod 容器
kubectl exec -it nginx-ingress-controller-77db54fc46-q8vp7 -n ingress-nginx -- /bin/bash

# 查看运行的进程
ps -ef

可以看到 nginx-ingress-controller Pod 容器中运行的是 nginx 程序,我们再查看以下 nginx.conf 配置文件

配置文件中自动生成了 www.httpd.com 和 www.nginx.com 的服务配置

访问测试

  • 查询 Ingress-Nginx 部署节点
kubectl get po -n ingress-nginx -o wide
  • 修改本机的 hosts 文件
vi /etc/host

192.168.143.132 www.nginx.com
192.168.143.132 www.httpd.com
  • 访问网站,查看内容

基于多个子域名配置

apiVersion: extensions/v1beta1
kind: Ingress
metadata:
  name: web
  annotations:
    Kubernetes.io/ingress.class: "nginx"
spec:
  rules:
  - host: webservice.com
    http:
      paths:
      - path: /httpd
        backend:
          serviceName: httpd
          servicePort: 80
      - path: /nginx
        backend:
          serviceName: nginx
          servicePort: 80

其他的配置测试与上面一致。

相关推荐

全网第一个讲清楚CPK如何计算的Step by stepExcel和Python同时实现

在网上搜索CPK的计算方法,几乎全是照搬教材的公式,在实际工作做作用不大,甚至误导人。比如这个又比如这个:CPK=min((X-LSL/3s),(USL-X/3s))还有这个,很规范的公式,也很清晰很...

[R语言] R语言快速入门教程(r语言基础操作)

本文主要是为了从零开始学习和理解R语言,简要介绍了该语言的最重要部分,以快速入门。主要参考文章:R-TutorialR语言程序的编写需要安装R或RStudio,通常是在RStudio中键入代码。但是R...

Python第123题:计算直角三角形底边斜边【PythonTip题库300题】

1、编程试题:编写一个程序,找出已知面积和高的直角三角形的另外两边(底边及斜边)。定义函数find_missing_sides(),有两个参数:area(面积)和height(高)。在函数内,计算另外...

Tensor:Pytorch神经网络界的Numpy

TensorTensor,它可以是0维、一维以及多维的数组,你可以将它看作为神经网络界的Numpy,它与Numpy相似,二者可以共享内存,且之间的转换非常方便。但它们也不相同,最大的区别就是Numpy...

python多进程编程(python多进程进程池)

forkwindows中是没有fork函数的,一开始直接在Windows中测试,直接报错importosimporttimeret=os.fork()ifret==0:...

原来Python的协程有2种实现方式(python协程模型)

什么是协程在Python中,协程(Coroutine)是一种轻量级的并发编程方式,可以通过协作式多任务来实现高效的并发执行。协程是一种特殊的生成器函数,通过使用yield关键字来挂起函数的执行...

ob混淆加密解密,新版大众点评加密解密

1目标:新版大众点评接口参数_token加密解密数据获取:所有教育培训机构联系方式获取难点:objs混淆2打开大众点评网站,点击教育全部,打开页面,切换到mobile模式,才能找到接口。打开开发者工具...

python并发编程-同步锁(python并发和并行)

需要注意的点:1.线程抢的是GIL锁,GIL锁相当于执行权限,拿到执行权限后才能拿到互斥锁Lock,其他线程也可以抢到GIL,但如果发现Lock仍然没有被释放则阻塞,即便是拿到执行权限GIL也要立刻...

10分钟学会Python基础知识(python基础讲解)

看完本文大概需要8分钟,看完后,仔细看下代码,认真回一下,函数基本知识就OK了。最好还是把代码敲一下。一、函数基础简单地说,一个函数就是一组Python语句的组合,它们可以在程序中运行一次或多次运行。...

Python最常见的170道面试题全解析答案(二)

60.请写一个Python逻辑,计算一个文件中的大写字母数量答:withopen(‘A.txt’)asfs:count=0foriinfs.read():ifi.isupper...

Python 如何通过 threading 模块实现多线程。

先熟悉下相关概念多线程是并发编程的一种方式,多线程在CPU密集型任务中无法充分利用多核性能,但在I/O操作(如文件读写、网络请求)等待期间,线程会释放GIL,此时其他线程可以运行。GIL是P...

Python的设计模式单例模式(python 单例)

单例模式,简单的说就是确保只有一个实例,我们知道,通常情况下类其实可以有很多实例,我们这么来保证唯一呢,全局访问。如配置管理、数据库连接池、日志处理器等。classSingleton: ...

更安全的加密工具:bcrypt(bcrypt加密在线)

作为程序员在开发工作中经常会使用加密算法,比如,密码、敏感数据等。初学者经常使用md5等方式对数据进行加密,但是作为严谨开发的程序员,需要掌握一些相对安全的加密方式,今天给大家介绍下我我在工作中使用到...

一篇文章搞懂Python协程(python协程用法)

前引之前我们学习了线程、进程的概念,了解了在操作系统中进程是资源分配的最小单位,线程是CPU调度的最小单位。按道理来说我们已经算是把cpu的利用率提高很多了。但是我们知道无论是创建多进程还是创建多线...

Python开发必会的5个线程安全技巧

点赞、收藏、加关注,下次找我不迷路一、啥是线程安全?假设你开了一家包子铺,店里有个公共的蒸笼,里面放着刚蒸好的包子。现在有三个顾客同时来拿包子,要是每个人都随便伸手去拿,会不会出现混乱?比如第一个顾...

取消回复欢迎 发表评论: