nginx配置ip_hash负载均衡策略

一、nginx配置ip_hash负载均衡策略

nginx默认的负载均衡策略为轮询,某些场景需要使用ip_hash负载策略,即:同一个ip地址,永远访问nginx后面同一台tomcat。配置示例如下,主要是设置ip_hash:

	upstream www.abc.com{ip_hash;server 202.119.11.23:8899;server 172.168.10.99:8899;server 202.119.11.121:8899;}

二、配置后如何验证ip_hash有没有生效

1、需要打开nginx的access log查看请求来自哪个ip、访问哪个负载。

(1)首先,配置access日志格式;

(2)其次,打开access日志;

(3)验证后注意关闭access日志。

2、完整示例如下


#表示使用几个nginx线程,一般取值为cpu个数-1
worker_processes  1;#是否打开error日志,及error日志路径
error_log  logs/error.log;#pid        logs/nginx.pid;events {worker_connections  1024;
}http {include       mime.types;default_type  application/octet-stream;client_max_body_size 2048m;#access日志格式##$remote_addr:表示客户端ip##$time_local:表示记录日志的本地时间##$upstream_addr:表示负载到后端的哪台tomcat##$request_time:从接收到客户端请求到发送完响应给客户端所经过的时间,单位为秒##$status:表示响应码log_format  log_custom  '$remote_addr -- [$time_local] -- "$upstream_addr" -- $request_time -- $status -- "$request"';#开启access日志,log_custom表示指定日志格式。##注意:开始access日志方式是如下方式,并不是access_log on方式;关闭access日志方式是:access_log off;access_log  logs/access.log log_custom;sendfile        on;#tcp_nopush     on;#keepalive_timeout  0;keepalive_timeout  65;#gzip  on;upstream www.abc.com{ip_hash;server 202.119.11.23:8899;server 172.168.10.99:8899;server 202.119.11.121:8899;}server {listen       80;server_name  localhost;location ^~ /api-base {proxy_http_version 1.1;proxy_redirect off;proxy_set_header Connection "";proxy_set_header Host $host;proxy_set_header X-Real-IP $remote_addr;proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;proxy_pass http://www.abc.com;}}
}

3、对应的日志效果

三、ip_hash算法对应的java代码示例

package com.nation.net;import java.net.InetAddress;
import java.util.Arrays;
import java.util.List;
import java.util.concurrent.atomic.AtomicInteger;/*** nginx ip_hash算法示例**/
public class IpHashLoadBalancer {private final List<String> servers;private final AtomicInteger currentIndex = new AtomicInteger(0);public IpHashLoadBalancer(List<String> servers) {this.servers = servers;}public String selectServer(String clientIp) {try {// 将客户端IP地址转换为字节数组byte[] ipBytes = InetAddress.getByName(clientIp).getAddress();// 使用MD5算法计算哈希值byte[] hashBytes = java.security.MessageDigest.getInstance("MD5").digest(ipBytes);// 将哈希值转换为正整数int hash = 0;for (byte b : hashBytes) {hash <<= 8;hash ^= (b & 0xFF);}// 使用哈希值选择服务器int serverIndex = Math.abs(hash) % servers.size();// 如果有必要,可以在这里实现一个轮询机制,使得下一次请求可能选择另一个服务器// currentIndex.incrementAndGet();// int serverIndex = currentIndex.getAndIncrement() % servers.size();return servers.get(serverIndex);} catch (Exception e) {e.printStackTrace();return null;}}public static void main(String[] args) {//负载地址List<String> servers = Arrays.asList("202.119.11.23","172.168.10.99","202.119.11.121");IpHashLoadBalancer loadBalancer = new IpHashLoadBalancer(servers);// 假设客户端IP地址String clientIp = "172.168.10.187";// 选择服务器String selectedServer = loadBalancer.selectServer(clientIp);System.out.println("Selected server: " + selectedServer);}
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/661373.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【PCB专题】案例:PCB出货报告会体现什么信息?

不知道在实际的生活中大家有没有拿到一个设备或东西看用户手册的习惯。比如拿到一个电风扇看一下说明书怎么使用,怎么安装,怎么做维护等。 一般情况下我拿到东西会先抽一点时间看一下用户手册学习如何使用,如果说明书比较重要的话会保留起来。本文章其实就是PCB打样后供应商…

ES集群分布式查询原理

集群分布式查询 elasticsearch的查询分成两个阶段&#xff1a; scatter phase&#xff1a;分散阶段&#xff0c;coordinating node会把请求分发到每一个分片gather phase&#xff1a;聚集阶段&#xff0c;coordinating node汇总data node的搜索结果&#xff0c;并处理为最终结…

Avalonia .NET构建Linux桌面应用

目录 &#x1f47b;前言 &#x1f4bb;安装Avalonia &#x1f4e6;创建项目 &#x1f4da;在win下运行 ​&#x1f511;打包发布​编辑 &#x1f4fb;在linux下运行 环境WIN10 VS2022 debian &#x1f47b;前言 Avalonia 是一个用于创建跨平台用户界面 (UI) 的开源框架…

QT之信号和槽

在刚刚了解Qt的时候&#xff0c;为了通过按钮显示 hello world 的时候曾说明过信号与槽&#xff0c;虽然没有细说&#xff0c;不过也算是接触过。 而本文就会细细说明什么是 Qt 的信号与槽。 概念初识 在 linux 学进程相关的内容的时候&#xff0c;曾了解过信号是操作系统控…

数据仓库和数据仓库分层

一、数据仓库概念 数据仓库(Data Warehouse)&#xff0c;可简写为DW或DWH。数据仓库&#xff0c;是为企业所有级别的决策制定过程&#xff0c;提供所有类型数据支持的战略集合。它是单个数据存储&#xff0c;出于分析性报告和决策支持目的而创建。 为需要业务智能的企业&#…

基于STC12C5A60S2系列1T 8051单片机的Proteus中的单片机发送一帧或一串数据给串口调试助手软件接收区显示出来的串口通信应用

基于STC12C5A60S2系列1T 8051单片机的Proteus中的单片机发送一帧或一串数据给串口调试助手软件接收区显示出来的串口通信应用 STC12C5A60S2系列1T 8051单片机管脚图STC12C5A60S2系列1T 8051单片机串口通信介绍STC12C5A60S2系列1T 8051单片机串口通信的结构基于STC12C5A60S2系列…

动手学深度学习3.6 softmax回归的从零开始实现-笔记练习(PyTorch)

以下内容为结合李沐老师的课程和教材补充的学习笔记&#xff0c;以及对课后练习的一些思考&#xff0c;自留回顾&#xff0c;也供同学之人交流参考。 本节课程地址&#xff1a;Softmax 回归从零开始实现_哔哩哔哩_bilibili 本节教材地址&#xff1a;3.6. softmax回归的从零开…

【最大公约数 排序】2344. 使数组可以被整除的最少删除次数

本文涉及知识点 最大公约数 排序 LeetCode2344. 使数组可以被整除的最少删除次数 给你两个正整数数组 nums 和 numsDivide 。你可以从 nums 中删除任意数目的元素。 请你返回使 nums 中 最小 元素可以整除 numsDivide 中所有元素的 最少 删除次数。如果无法得到这样的元素&a…

讯饶科技 X2Modbus 敏感信息泄露

讯饶科技 X2Modbus 敏感信息泄露 文章目录 讯饶科技 X2Modbus 敏感信息泄露漏洞描述影响版本实现原理漏洞复现修复建议 漏洞描述 X2Modbus是一款功能很强大的协议转换网关&#xff0c; 这里的X代表各家不同 的通信协议&#xff0c;2是To的谐音表示转换&#xff0c;Modbus就是最…

企业家如何拥有良好口才的能力(3篇)

企业家如何拥有良好口才的能力&#xff08;3篇&#xff09; **篇&#xff1a;企业家提升口才能力的基石 一、引言 作为企业家&#xff0c;口才不仅是沟通的工具&#xff0c;更是展现领导魅力和企业形象的窗口。本文将探讨企业家如何拥有良好口才能力的基石。 二、清晰的目标与…

用Docker 创建并运行一个MySQL容器

可以在DockerHub官网上荡:mysql - Official Image | Docker Hub 指令是:docker pull mysql; 因为文件比较大可能时间比较长&#xff0c;我是跟着黑马的课走的 课程提供的有文件&#xff0c;我就用已有的资源了。 在tmp目录里放入mysql.tar包 然后cd进去 输入指令:docker lo…

Android binder死亡通知机制

在Andorid 的binder系统中&#xff0c;当Bn端由于种种原因死亡时&#xff0c;需要通知Bp端&#xff0c;Bp端感知Bn端死亡后&#xff0c;做相应的处理。 使用 Bp需要先注册一个死亡通知&#xff0c;当Bn端死亡时&#xff0c;回调到Bp端。 1&#xff0c;java代码注册死亡通知 …