当前位置:首页 > 技术文章 > 正文内容

如何在kubernetes中配置转发和代理

arlanguage3个月前 (01-31)技术文章23

Kubernetes中HTTP请求的代理和转发使用场景比较多,这里对代理和转发各举一个例子。

  • 环境

笔者这里使用的Ingress Controller是“NGINX Ingress Controller”,版本是“1.7.1”,Kubernetes的版本是“1.25.6”。

  • 转发配置

因业主的要求,对原本运行在数据中心A的服务做了迁移,服务迁移后,原有的域名因已广播出去,短期内不做下线处理,客户访问老的域名也需要跳转到服务,这里通过配置转发来解决,具体的配置如下,

apiVersion: networking.k8s.io/v1
kind: Ingress
metadata:
  annotations:
    nginx.ingress.kubernetes.io/rewrite-target: "https://www.b-site.com/$2"
  name: rewrite-target
  namespace: my-app
spec:
  rules:
  - host: www.a-site.com
    http:
      paths:
      - backend:
          service: 
            name: outer-service
            port: 
               number: 80
        path: /outer/(/|$)(.*)
        pathType: Prefix

通过配置重写,新的域名可以提供服务,老的域名也得以保留。原理很简单,它是通过Nginx的rewrite指令实现的302重定向。

  • 代理配置

Kubernetes中,实际的服务可以不用运行在集群内。人为配置“endpoints”和“service”,通过内部的服务名来访问运行在集群外的服务。

私有化部署的服务,需要访问一个外部第三方接口,其仅能通过http访问,而部署在Kubernetes中的服务都通过https访问,为了解决Chrome浏览器报出的“Mixed Content”异常,

这里配置代理访问,前端页面便可以使用https来请求第三方接口,配置如下,

---
apiVersion: v1
kind: Endpoints
metadata:
  name: external-service
  namespace: my-app
subsets:
  - addresses:
      - ip: 123.123.123.123 #第三方接口ip
    ports:
      - port: 8000              # 第三方服务的端口
---
apiVersion: v1
kind: Service
metadata:
  name: external-service
  namespace: my-app
spec:
  ports:
  - protocol: TCP
    port: 80
    targetPort: 8000
---
apiVersion: networking.k8s.io/v1
kind: Ingress
metadata:
  name: external-ingress
  namespace: my-app
spec:
  ingressClassName: nginx
  tls:
  - hosts:
    - '*.a-site.com'
    secretName: ssl-key
  rules:
  - host: www.a-site.com
    http:
      paths:
      - path: /outer/
        pathType: Prefix
        backend:
          service:
            name: external-service
            port:
              number: 80

上面配置中,“www.a-site.com”是使用https访问的,通过配置代理,请求路径以“/outer/”开头的链接都将代理到第三方的接口,这样Chrome就不会报“Mixed Content”异常了。

在Kubernetes中,service使用selector来绑定和自己同名的endpoints,这里我们手动配置同名的endpoints和service来实现service与endpoints的绑定。

文章对Kubernetes中“NGINX Ingress Controller”的转发和代理配置做了简单举例,希望能对你平时的工作有所启发,感谢阅读和评论!

扫描二维码推送至手机访问。

版权声明:本文由AR编程网发布,如需转载请注明出处。

本文链接:http://www.arlanguage.com/post/1573.html

分享给朋友:

“如何在kubernetes中配置转发和代理” 的相关文章

nginx开启ssl并把http重定向到https的两种方式

1 简介Nginx是一个非常强大和流行的高性能Web服务器。本文讲解Nginx如何整合https并将http重定向到https。https相关文章如下:(1)Springboot整合https原来这么简单(2)HTTPS之密钥知识与密钥工具Keytool和Keystore-Explorer(3)Sp...

NGINX最常用的指令(备用查询)

服务管理sudo systemctl status nginx # nginx当前状态 sudo systemctl reload nginx # 重新加载 nginx sudo systemctl restart nginx # 重启nginx sudo nginx -t # 检查语法 ng...

Nuxt.js从0到1之入门教程

题外话:近来想把网站做下更新,从框架到内容的更新,但又不想放弃SEO的优势,日常工作用到vue.js在SEO方面劣势较多,果断选择了Nuxt.js,苦于国内文章抄袭的非常严重 如某n 某书,最终在稀土找到一篇像样的文章,以头条为平台记录网站改版全过程。此文章建议在PC端查看,涉及到代码部分,移动端查...

Nginx 如何代理转发传递真实 ip 地址?

Nginx 是一个高性能的反向代理服务器,也是一个非常流行的负载均衡器和 HTTP 缓存。其轻量级的设计和高并发处理能力使得它广泛应用于各种 Web 服务中。在使用 Nginx 作为反向代理服务器时,一个常见的问题是如何在代理转发过程中传递客户端的真实 IP 地址。默认情况下,Nginx 会将客户端...

Nginx专题(1):Nginx之反向代理及配置

一、Nginx概念解读对于新事物的理解,最好的方式就是从概念入手,本文作为《Nginx专题》系列文章的第一篇,先从Nginx的名称开始来分解这个神秘的引擎。Nginx,是engine X的缩写,发音也是'engine x',2004年由俄罗斯大神伊戈尔·赛索耶夫开发,提供了高性能而易...

CentOS7服务器 Nginx离线升级教程

Nginx使用的版本 ≤ 1.21.5的Nginx版本存在漏洞。所以需要对Nginx进行升级。具体教程如下:1、确认安装的Nginx版本在任意目录下输入nginx -v,即可查看当前版本[root@master /]# nginx -v nginx version: nginx/1.12.2 [ro...