首页 > 系统相关 >使用 NGINX 在 Kubernetes 中对 TCP 和 UDP 流量进行负载均衡

使用 NGINX 在 Kubernetes 中对 TCP 和 UDP 流量进行负载均衡

时间:2022-12-07 16:04:02浏览次数:94  
标签:UDP Kubernetes Ingress TCP NGINX Controller mysql

原文作者:Amir Rawdat of F5
原文链接:​​​​使用 NGINX 在 Kubernetes 中对 TCP 和 UDP 流量进行负载均衡​

转载来源:NGINX 官方网站


除了 HTTP 流量之外,NGINX Ingress Controller 还可以负载 TCP 和 UDP 流量,因此您可以使用它来管理基于以下协议的各种应用和实用程序的流量,它们包括:

  • MySQL、LDAP 和 MQTT —— 许多流行应用使用的基于 TCP 协议的应用
  • DNS、syslog 和 RADIUS —— 边缘设备和非事务性应用使用的基于 UDP 协议的实用程序

在以下情况下,使用 NGINX Ingress Controller 进行 TCP 和 UDP 负载均衡也是一种将网络流量分发给 Kubernetes 应用的有效解决方案:

  • 您正在使用端到端加密 (EE2E),并且让应用(而非 NGINX Ingress Controller)来处理加密和解密
  • 您需要对基于 TCP 或 UDP 的应用实施高性能负载均衡
  • 在将现有网络 (TCP/UDP) 负载均衡器迁移到 Kubernetes 环境时,您希望尽量减少更改

NGINX Ingress Controller 自带两个支持 TCP/UDP 负载均衡的 NGINX Ingress 资源:

  • ​GlobalConfiguration​​ :集群管理员通常使用该资源指定可供 DevOps 团队使用的 TCP/UDP 端口(监听器)。注意,每个 NGINX Ingress Controller Deployment 只能配置一个 GlobalConfiguration 资源。
  • ​TransportServer​​:DevOps 团队通常使用该资源为应用配置 TCP/UDP 负载均衡。NGINX Ingress Controller 仅监听管理员在 GlobalConfiguration 资源中实例化的端口。这可以防止端口之间发生冲突,并确保 DevOps 团队仅向公共外部服务暴露管理员预先确定安全的端口,从而添加一层额外的安全性。

下图描述了 GlobalConfiguration 和 TransportServer 资源的用例示例。在 gc.yaml 中,集群管理员在 GlobalConfiguration 资源中定义了 TCP 和 UDP 监听器。在 ts.yaml 中,DevOps 工程师在 TransportServer 资源中引用了 TCP 监听器,以便将流量路由到 MySQL Deployment。

使用 NGINX 在 Kubernetes 中对 TCP 和 UDP 流量进行负载均衡_TCP

gc.yaml 中的 GlobalConfiguration 资源定义了两个监听器:端口 514 的 UDP 监听器,用于连接 syslog 服务;端口 5353 的 TCP 监听器,用于连接 MySQL 服务。

apiVersion: k8s.nginx.org/v1alpha1
kind: GlobalConfiguration
metadata:
name: nginx-configuration
namespace: nginx-ingress
spec:
listeners:
- name: syslog-udp
port: 541
protocol: UDP
- name: mysql-tcp
port: 5353
protocol: TCP

在 ts.yaml 中,TransportServe 资源的第 6-8 行通过 name (​​mysql-tcp​​) 引用了 gc.yaml 中定义的 TCP 监听器,第 9-14 行定义了将 TCP 流量发送到 ​​mysql-db​​ upstream 的路由规则。

 apiVersion: k8s.nginx.org/v1alpha1
kind: TransportServer
metadata:
name: mysql-tcp
spec:
listener:
name: mysql-tcp
protocol: TCP
upstreams:
- name: mysql-db
service: mysql
port: 3306
action:
pass: mysql-db

在这个例子中,DevOps 工程师使用 MySQL 客户端来验证配置是否有效,这可以通过 MySQL deployment 中的 ​​rawdata_content_schema​​ 数据库的表目录输出来确认。

$ echo “SHOW TABLES” | mysql –h <external_IP_address> -P <port> -u <user> –p rawdata_content_schema 
Enter Password: <password>
Tables_in_rawdata_content_schema
authors
posts

UDP 流量的 TransportServer 资源配置方法与之类似;有关完整示例,请参见在 GitHub 上的 NGINX Ingress Controller 仓库中的“​​基础 TCP/UDP 负载均衡​​”。高级 NGINX 用户可以使用原生 NGINX 配置(使用 ​​stream-snippets​​ ConfigMap 键)扩展 TransportServer 资源,如仓库中的“​​支持 TCP/UDP 负载均衡​​”一例所示。

如欲详细了解您可以在 TransportServer 资源中配置的特性,请参阅 ​​NGINX Ingress Controller 文档​​。

立即体验基于 NGINX Plus 的 NGINX Ingress Controller 的 ​​30 天免费试用版​​​,或者​​联系我们讨论您的用例​​。


更多资源

想要更及时全面地获取 NGINX 相关的技术干货、互动问答、系列课程、活动资源?

请前往 NGINX 开源社区:

官网:  ​​https://www.nginx.org.cn/​

微信公众号: ​​ https://mp.weixin.qq.com/s/XVE5yvDbmJtpV2alsIFwJg​

微信群: ​​ https://www.nginx.org.cn/static/pc/images/homePage/QR-code.png?v=1621313354​

B 站:  ​​https://space.bilibili.com/628384319​

标签:UDP,Kubernetes,Ingress,TCP,NGINX,Controller,mysql
From: https://blog.51cto.com/u_15363550/5919624

相关文章

  • Zabbix监控Nginx
      在实际生产中会经常需要自定义一些各种中间件的监控项,自己一个个添加的话太繁琐了,之所以在zabbix官网和第三方网站都会提供大量的监控模板,有的写的非常可以,我们在生产中......
  • Nginx常用命令
    查看版本号./nginx-v启动./nginx查看状态ps-ef|grepnginx停止./nginx-sstop重启./nginx-sreload ......
  • 一、kubernetes介绍
    1、kubernetes基本介绍kubernetes,简称K8s,是用8代替8个字符“ubernete”而成的缩写。是一个开源的,用于管理云平台中多个主机上的容器化的应用,Kubernetes的目标是让部......
  • Kubernetes configmap 笔记
    ConigMap什么是ConfigMapConfigMap采用key-value格式进行保存数据,一般用来保存非敏感数据,Pods可以将configmap作为环境变量、命令行参数或卷中的配置文件使用。Config......
  • Kubernetes静态Pod
    一、什么是StaticPod静态Pod在指定的节点上由kubelet守护进程直接管理,不需要API服务器监管。与由控制面管理的Pod(例如,Deployment、RC、DaemonSet)不同;kubelet......
  • nginx: [emerg] no "events" section in configuration
    添加events,如下图http{includemime.types;default_typeapplication/octet-stream;keepalive_timeout65;server{listen80......
  • CentOS下nginx版本平稳升级记录
    起因:系统漏洞扫描出高危漏洞:CVE-2019-9513/CVE-2019-9511/CVE-2019-9516,需升级nginx。下载地址:https://nginx.org/en/download.html,选择了稳定版本1.22.1。将下载......
  • 在windows下导入react项目并且打包编译后部署到nginx上
     在windows下导入react项目并且打包编译后部署到nginx上一、安装npm二、创建react项目三、安装nginx四、总结最近接手了公司的一个django项目,这是应该前后端分......
  • nginx解决vue跨域问题
    location/epayapi{proxy_passhttp://127.0.0.1:7011;proxy_set_headerHost$host;proxy_set_headerX-Real-IP$remote_addr;proxy_set_headerX......
  • centos 7.6 部署spring自动化运维环境一nginx安装
    首先安装所需的环境一.安装PCREpcre-devel#####yuminstall-ypcrepcre-devel二.安装gcc#####yum-yinstallgccgcc-c++kernel-devel三.安装zlib#####yumins......