实现Nginx四层负载均衡

news/2024/9/18 12:35:01/ 标签: nginx, 负载均衡, 运维

Nginx在1.9.0版本开始支持tcp模式的负载均衡,在1.9.13版本开始支持udp协议的负载,udp主要用于 DNS的域名解析,其配置方式和指令和http 代理类似,其基于ngx_stream_proxy_module模块实现tcp 负载,另外基于模块ngx_stream_upstream_module实现后端服务器分组转发、权重分配、状态监测、 调度算法等高级功能。

如果编译安装,需要指定 --with-stream 选项才能支持ngx_stream_proxy_module模块

官方文档:Module ngx_stream_proxy_module

一、TCP负载均衡配置参数

stream { #定义stream相关的服务;
Context:mainupstream backend { #定义后端服务器hash $remote_addr consistent; #定义调度算法server backend1.example.com:12345 weight=5; #定义具体serverserver 127.0.0.1:12345      max_fails=3 fail_timeout=30s;server unix:/tmp/backend3;}upstream dns {   #定义后端服务器server 10.0.0.1:53;   #定义具体serverserver dns.example.com:53;}server { #定义serverlisten 12345; #监听IP:PORTproxy_connect_timeout 1s; #连接超时时间proxy_timeout 3s; #转发超时时间proxy_pass backend; #转发到具体服务器组}server {listen 127.0.0.1:53 udp reuseport;proxy_timeout 20s;proxy_pass dns;}server {listen [::1]:12345;proxy_pass unix:/tmp/stream.socket;}
}

二、负载均衡:MySQL

1、后端服务器安装MySQL

[root@apache20 ~]# yum install mariadb-server -y

[root@apache20 ~]# vim /etc/my.cnf.d/mariadb-server.cnf

[mysqld]

server-id=20

[root@apache20 ~]# systemctl start mariadb

[root@apache20 ~]# mysql -e "grant all on *.* to oqs@'%' identified by '123456';"

[root@apache30 ~]# mysql -uoqs -p123456 -h172.25.254.20 -e "select @@server_id"

[root@apache30 ~]# yum install mariadb-server -y

[root@apache30 ~]# vim /etc/my.cnf.d/mariadb-server.cnf

[mysqld]

server-id=30

[root@apache30 ~]# systemctl start mariadb

[root@apache30 ~]# mysql -e "grant all on *.* to oqs@'%' identified by '123456';"

[root@apache30 ~]# mysql -uoqs -p123456 -h172.25.254.20 -e "select @@server_id"

 2、nginx配置

[root@Nginx ~]# vim /usr/local/nginx/conf/nginx.conf

[root@Nginx ~]# vim /usr/local/nginx/conf/tcp/tcp.conf

重启nginxnginx -s reload

3、测试

三、UDP负载均衡:DNS

1、nginx配置:

[root@Nginx ~]# vim /usr/local/nginx/conf/tcp/tcp.conf


重启nginxnginx -s reload

2、后端做dns正向解析

[root@client ~]# vim /etc/named.rfc1912.zones

[root@client ~]# vim /var/named/qisheng.org.zone

 

两个后端服务器都要dns正向解析。

重启服务:systemctl restart named

3、测试


http://www.ppmy.cn/news/1516211.html

相关文章

零基础5分钟上手亚马逊云科技核心云架构知识-创建NoSQL数据库

简介: 欢迎来到小李哥全新亚马逊云科技AWS云计算知识学习系列,适用于任何无云计算或者亚马逊云科技技术背景的开发者,通过这篇文章大家零基础5分钟就能完全学会亚马逊云科技一个经典的服务开发架构方案。 我会每天介绍一个基于亚马逊云科技…

左手阿维塔右手深蓝,华为抢占高端及主流市场

在新能源汽车领域,一场由科技巨头引领的变革正在加速推进。 8月20日,阿维塔与华为正式签约并宣布入股引望智能技术有限公司,这一战略合作不仅标志着阿维塔在高端汽车市场的布局进一步深化,而且还预示着华为将与长安旗下的深蓝品牌…

[ICS] 物理安全

工业控制系统安全气泡类比 这个理念是,为了防御那些无法更新到最新安全控制措施的旧系统,或者由于设备资源有限而无法处理安全控制措施的系统,帮助可视化这种设备的安全策略可以将它们放置在一个肥皂泡或玻璃泡中。泡中的系统和设备彼此信任…

idea 项目启动慢,报内存溢出,调整jvm参数

idea 项目启动慢,直接报内存溢出了 java: java.lang.OutOfMemoryError: Java heap space 解决方案:调整 idea jvm参数 在IntelliJ IDEA中,可以通过以下步骤来全局设置Java堆大小: 打开IntelliJ IDEA。从菜单栏选择 “Help” &…

Transformer模型、强化学习、深度学习模型可解释性与可视化方法、注意力机制、目标检测算法、图神经网络、强化学习

近年来,伴随着以卷积神经网络(CNN)为代表的深度学习的快速发展,人工智能迈入了第三次发展浪潮,AI技术在各个领域中的应用越来越广泛。 抽丝剥茧、深入浅出讲解注意力机制、Transformer模型(BERT、GPT-1/2/…

Servlet---Web会话跟踪 ▎token令牌

▍为什么要进行Web会话跟踪? http请求是无状态的,不携带用户信息的,当用户登录成功后,之后在于服务器交互时,服务器并不知道是哪个用户发送的请求 ▍Web会话跟踪 解决方法:在用户成功登录后,后端向前端响应token令牌(token令牌:用户信息),前端保存token令牌每次访问后端都先…

RabbitMQ如何保证消息不丢失

RabbitMQ消息丢失的三种情况 第一种:生产者弄丢了数据。生产者将数据发送到 RabbitMQ 的时候,可能数据就在半路给搞丢了,因为网络问题啥的,都有可能。 第二种:RabbitMQ 弄丢了数据。MQ还没有持久化自己挂了。 第三种…

C++类和对象(总篇)

文章目录 C类和对象1、类的定义1.1类定义格式1.2访问限定符1.3类域 2、实例化2.1实例化概念 3、this指针4、类的默认成员函数5、构造函数5.1构造函数的特点5.2实例分析 6、析构函数6.1析构函数的特点6.2实例分析 7、拷贝构造函数7.1 拷贝构造函数的特点7.2实例分析7.3浅拷贝和深…

【linux中高级命令】

杀进程 1、lsof列出所有打开的文件,‌包括网络连接,‌从而提供关于系统状态的宝贵信息‌ #可以直接查看端口的进程 lsof -i:端口获取到进程,使用kill命令和PID来终止进程 kill -9 [PID]2、列出使用该端口的进程信息,‌包括PID …

基于Python的mediapipe和opencv的人体骨骼、人体姿态关键点的实时跟踪项目

随着计算机视觉技术的发展,人体姿态估计在虚拟现实、运动分析、人机交互等领域得到了广泛应用。传统的姿态估计方法通常依赖于深度学习模型,需要大量的计算资源。而 Google 开发的 MediaPipe 框架则提供了高效且易于使用的解决方案,它可以在各…

如何解决git@github.com: Permission denied (publickey)异常

如何解决gitgithub.com: Permission denied异常 一、错误信息描述二、解决办法2.1、获取本地SSH Key2.2、将本地的SSH Key添加到github 一、错误信息描述 gitgithub.com: Permission denied (publickey). fatal: Could not read from remote repository. Please make sure you …

LlamaIndex 实现 RAG(四)- RAG 跟踪监控

RAG 整个流程不复杂,集成三大部分包括文档解析并生成向量、根据查询问题查找语意相似的数据文档块、把查询问题和召回文档作为上下文的数据传给模型进行解答。大语言模型的应用开发和传统的开发方式区别很大,以前开发完成,只要逻辑正确&#…

linux系统使用 docker 来部署web环境 nginx+php7.4 并配置称 docker-compose-mysql.yml 文件

Docker是一个开源的容器化平台,旨在简化应用程序的创建、部署和管理。它基于OS-level虚拟化技术,通过将应用程序和其依赖项打包到一个称为容器的标准化单元中,使得应用程序可以在任何环境中快速、可靠地运行。 Docker的优势有以下几个方面&a…

乐鑫蓝牙Mesh协议栈ESP-BLE-MESH方案,设备智能连接通信的桥梁

随着科技的不断进步,智能家居已经不再是科幻小说中的梦想,而是触手可及的现实。在这场智能化革命中,蓝牙Mesh技术以其卓越的稳定性和扩展性,成为了连接家庭中每一个智能设备的桥梁。 它像一张隐形的网,将无数设备紧密…

C++基础语法:while的使用

前言 "打牢基础,万事不愁" .C的基础语法的学习."学以致用,边学边用",编程是实践性很强的技术,在运用中理解,总结. 引入 while的使用是编写代码的基础内容.笔者的记忆力已不如以前,最近遇到了还花了不少功夫,可见是掌握地不够牢固.所以对while的思路和内容…

爬取央视热榜并存储到MongoDB

1. 环境准备 在开始之前,确保你已经安装了以下Python库: pip install requests pymongo2. 爬取网页内容 首先,我们需要爬取央视热榜的网页内容。通过requests.get()方法,我们可以获取网页的HTML内容,并通过re.finda…

回归预测|基于北方苍鹰优化NGO-Transformer-GRU组合模型的数据预测Matlab程序多特征输入单输出

回归预测|基于北方苍鹰优化NGO-Transformer-GRU组合模型的数据预测Matlab程序多特征输入单输出 文章目录 前言回归预测|基于北方苍鹰优化NGO-Transformer-GRU组合模型的数据预测Matlab程序多特征输入单输出 一、NGO-Transformer-GRU模型NGO-Transformer-GRU组合模型的数据预测1…

JAVA_11

JAVA_11 JAVA容器1. 容器 JAVA容器 1. 容器 整体结构 //有序、可重复 List list new ArrayList();//泛型 System.out.println(list.isEmpty());List.add("高淇"); System.out.println(list);System.out.printin(list.isEmpty());List.add("高三");list…

流媒体服务器如何让WebRTC支持H.265,同时又能支持Web js硬解码、软解码(MSE硬解、WASM软解)

为了这一整套的解决方案,调研研发整整花费了差不多半年多的时间,需达成的目标: 流媒体服务器端不需要将H.265转码成H.264,就能让Chrome解码播放H.265; 注意:现在很多市面上的软硬件通过转码H.265成H.264的…

HaProxy学习 —300K的TCP Socket并发连接实现(翻译)

HaProxy学习 —300K的TCP Socket并发连接实现(翻译) 1 原文链接2 原文翻译2.1 调整Linux系统参数2.2 调整HAProxy 1 原文链接 Use HAProxy to load balance 300k concurrent tcp socket connections: Port Exhaustion, Keep-alive and others&#xff0…