点赞
评论
收藏
分享
举报
使用 NGINX 在 Kubernetes 中对 TCP 和 UDP 流量进行负载均衡
发表于2022-11-16 11:59

浏览 1.3k

文章标签

原文作者: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。

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

 1 apiVersion: k8s.nginx.org/v1alpha1
 2 kind: GlobalConfiguration 
 3 metadata:
 4   name: nginx-configuration
 5   namespace: nginx-ingress
 6 spec: 
 7   listeners:
 8   - name: syslog-udp
 9     port: 541
10     protocol: UDP
11   - name: mysql-tcp 
12     port: 5353 
13     protocol: TCP

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

 1 apiVersion: k8s.nginx.org/v1alpha1
 2 kind: TransportServer
 3 metadata:
 4   name: mysql-tcp
 5 spec:
 6   listener:
 7     name: mysql-tcp 
 8     protocol: TCP
 9 upstreams:
10 - name: mysql-db 
11   service: mysql 
12   port: 3306
13 action:
14   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 开源社区:

已修改于2023-03-08 22:12
本作品系原创
创作不易,留下一份鼓励
NGINX官方账号

暂无个人介绍

关注



写下您的评论
发表评论
全部评论(0)

按点赞数排序

按时间排序

关于作者
NGINX官方账号
这家伙很懒还未留下介绍~
243
文章
21
问答
198
粉丝
相关文章
介绍nginx网页配置工具QQ技术交流群1:1106758598QQ技术交流群2:560797506邮箱: cym1102@qq.com官网地址: http://www.nginxwebui.cn码云: https://gitee.com/cym1102/nginxWebUIgithub: https://github.com/cym1102/nginxWebUI功能特点nginxWebUI也可管理多个nginx服务器集群,随时一键切换到对应服务器上进行nginx配置,也可以一键将某台服务器配置同步到其他服务器,方便集群管理.部署此项目后,配置nginx再也不用上网各种搜索配置代码,再也不用手动申请和配置ssl证书,只需要在本项目中进行增删改查就可方便的配置和启动nginx。技术说明本项目是基于springBoot的web系统,数据库使用sqlite,因此服务器上不需要安装任何数据库项目启动时会释放一个.sqlite.db到系统用户文件夹中,注意进行备份本系统通过Let'sencrypt申请证书,使用acme.sh脚本
点赞 6
浏览 6.5k
  前三周学习了陶辉老师的“NGINX基础培训系列课程”,感觉受益良多,在这里想把一些知识点记录一下,和大家分享一下知识点,也方便日后的随手查看,温故知新。  首先,我们了解到了Nginx的版本,Nginx发布版本分为主线版本和稳定版本,区分两个版本也非常简单,主线版本版本号为单数,比如1.19,稳定版本为双数,比如1.18,今天我要说的是稳定版本,这个版本会尽量少的减少Nginx的bug问题,适用于生产环境,这里我不建议使用Nginx和其他软件一样在生产环境中落后一个或多个大版本使用,之前生产环境做过漏扫,发现我们编译自带的Nginx版本为:nginx/1.13.3(查询命令为nginx-V),结果出现了多个漏洞,四个高危和一个中危漏洞:        通过升级Nginx到稳定版最新版本后修复!  其次,是Nginx发行版本的选择,目前比较流行的有:nginx、nginxplus、Tengine、openresty、ope
点赞 1
浏览 3.6k
感谢您参加“NGINX从入门到精通进阶系列培训”!以下为培训的问答、课件和录像,希望您能通过此培训学有所得,祝学习进步!>问与答:- 基础篇+高级篇 - 应用篇+实战篇(New)>课件(PPT):基础篇:-NGINX概要、安装、配置:https://interact.f5.com/rs/653-SMC-783/images/CNFEB22-NginxCoreCourse-Setup.pdf-NGINX日志、运维:https://interact.f5.com/rs/653-SMC-783/images/cnfeb22-nginxcorecourse-maintenance.pdf高级篇:-NGINX变量、API:https://interact.f5.com/rs/653-SMC-783/images/CNFEB22-NginxCoreCourse-API.pdf-NGINXSSL、NJS:https://interact.f5.com/rs/653-SMC-783/images/CNFEB22-NginxCoreCourse-SSL.pdf
点赞 10
浏览 5k