Nginx第三方模块---nginx-sticky-module的使用(基于cookie的会话保持)

2024-03-29 08:04

本文主要是介绍Nginx第三方模块---nginx-sticky-module的使用(基于cookie的会话保持),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

目录

Nginx和Sticky介绍

编译安装sticky的nginx环境

安装过程碰到的问题和编译安装过程遇到的错误:

 (1)第一个错误:修改源代码ngx_http_sticky_module.c

 (2)第二个错误:修改源代码ngx_http_sticky_misc.c

 解决完以上两个错误,最后执行./configure --add-module=../nginx-sticky-module-ng && make && sudo make install,总算成功了

 nginx配置脚本(仅供参考)


 

 

Nginx和Sticky介绍

Nginx具有负载均衡的功能,纯 ip_hash 像局域网内的访问ip访问会导致ip倾斜 ,cookie_hash服务器给客户端下发一个cookie,具有特定cookie的请求会分配给它的发布者,cookie需要浏览器支持。

nginx在会话保持这方面比较弱,用ip_hash做会话保持有很大的缺陷,它是通过客户端ip来实现,根据访问ip的hash结果分配请求到后端的app服务器,负载不会很均匀。nginx-sticky-module这个第三方模块可以基于cookie实现会话保持。

d95e12dfbcfe4b96ab99ea029cd1c7d4.png

nginx-sticky-module模块是nginx实现负载均衡的一种方案,和ip_hash负载均衡算法会有区别的ip_hash 根据客户端ip将请求分配到不同的服务器上.

sticky 根据服务器个客户端的cookie,客户端再次请求是会带上此cookie,nginx会把有次cookie的请求转发到颁发cookie的服务器上.

编译安装sticky的nginx环境

(1)nginx版本:1.25.0

(2)sticky模块源码:git clone https://bitbucket.org/nginx-goodies/nginx-sticky-module-ng.git

f2a17f04c2f3403bb0606791912e7528.png

d6e61342c90842798afb2ddaa1dda06c.png

cd /k8s-deploygit clone https://bitbucket.org/nginx-goodies/nginx-sticky-module-ng.gitcd /k8s-deploy/nginx-1.25.0./configure --add-module=../nginx-sticky-module-ngmake && sudo make install
​

./configure --add-module=../nginx-sticky-module-ng

9768ad03285d455bbd0ede81d5000618.png

安装过程碰到的问题和编译安装过程遇到的错误:

make && sudo make install

 (1)第一个错误:修改源代码ngx_http_sticky_module.c

b44522b8046646a3a74ae40a51668941.png

执行命令:

0fcd1f0666a641a39a049d0fe422104e.png

cd /k8s-deploy/nginx-sticky-module-ngsed -i "s/ngx_http_parse_multi_header_lines.*/ngx_http_parse_multi_header_lines(r, r->headers_in.cookie, \&iphp->sticky_conf->cookie_name, \&route) != NULL){/g" ngx_http_sticky_module.c

 (2)第二个错误:修改源代码ngx_http_sticky_misc.c

7b1cc9078b22426ca85892416a936aa7.png

找到ngx_http_sticky_misc.c,增加两个库:

#include <openssl/sha.h>
#include <openssl/md5.h>

cd /k8s-deploy/nginx-sticky-module-ngvim ngx_http_sticky_misc.c# 增加声明,引入两个头文件,最后保存,如截图所示
#include <openssl/sha.h>
#include <openssl/md5.h>:wq

afcbc45f508f4b6094326b37dc1ea53b.png

016a502cb7c34e9bb8e55730dc579786.png

 解决完以上两个错误,最后执行./configure --add-module=../nginx-sticky-module-ng && make && sudo make install,总算成功了

345dec17fcd643ea9e8027a47ce2907a.png

 nginx配置脚本(仅供参考)

upstream iphashserver {
   #ip_hash;

   sticky;
   server 127.0.0.1:8071;
   server 127.0.0.1:8072;
}

server {
    listen       8000;
    server_name  localhost;

    location / {
        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_http_version 1.1;
        proxy_set_header Upgrade $http_upgrade;
        proxy_set_header Connection upgrade;

        proxy_connect_timeout    7200;
        proxy_read_timeout       7200;
        proxy_send_timeout       7200;

        add_header 'Access-Control-Allow-Origin' *;
        add_header 'Access-Control-Allow-Credentials' 'true';
        add_header 'Access-Control-Allow-Methods' *;
        add_header 'Access-Control-Allow-Headers' *;
        proxy_pass http://iphashserver;
        index  index.html index.htm;
    }
    error_page   500 502 503 504  /50x.html;
    location = /50x.html {
            root   html;
    }
}

 

这篇关于Nginx第三方模块---nginx-sticky-module的使用(基于cookie的会话保持)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/858061

相关文章

Java使用Mail构建邮件功能的完整指南

《Java使用Mail构建邮件功能的完整指南》JavaMailAPI是一个功能强大的工具,它可以帮助开发者轻松实现邮件的发送与接收功能,本文将介绍如何使用JavaMail发送和接收邮件,希望对大家有所... 目录1、简述2、主要特点3、发送样例3.1 发送纯文本邮件3.2 发送 html 邮件3.3 发送带

Nginx如何进行流量按比例转发

《Nginx如何进行流量按比例转发》Nginx可以借助split_clients指令或通过weight参数以及Lua脚本实现流量按比例转发,下面小编就为大家介绍一下两种方式具体的操作步骤吧... 目录方式一:借助split_clients指令1. 配置split_clients2. 配置后端服务器组3. 配

Nginx实现前端灰度发布

《Nginx实现前端灰度发布》灰度发布是一种重要的策略,它允许我们在不影响所有用户的情况下,逐步推出新功能或更新,通过灰度发布,我们可以测试新版本的稳定性和性能,下面就来介绍一下前端灰度发布的使用,感... 目录前言一、基于权重的流量分配二、基于 Cookie 的分流三、基于请求头的分流四、基于请求参数的分

使用DeepSeek搭建个人知识库(在笔记本电脑上)

《使用DeepSeek搭建个人知识库(在笔记本电脑上)》本文介绍了如何在笔记本电脑上使用DeepSeek和开源工具搭建个人知识库,通过安装DeepSeek和RAGFlow,并使用CherryStudi... 目录部署环境软件清单安装DeepSeek安装Cherry Studio安装RAGFlow设置知识库总

Python FastAPI入门安装使用

《PythonFastAPI入门安装使用》FastAPI是一个现代、快速的PythonWeb框架,用于构建API,它基于Python3.6+的类型提示特性,使得代码更加简洁且易于绶护,这篇文章主要介... 目录第一节:FastAPI入门一、FastAPI框架介绍什么是ASGI服务(WSGI)二、FastAP

Spring-AOP-ProceedingJoinPoint的使用详解

《Spring-AOP-ProceedingJoinPoint的使用详解》:本文主要介绍Spring-AOP-ProceedingJoinPoint的使用方式,具有很好的参考价值,希望对大家有所帮... 目录ProceedingJoinPoijsnt简介获取环绕通知方法的相关信息1.proceed()2.g

Maven pom.xml文件中build,plugin标签的使用小结

《Mavenpom.xml文件中build,plugin标签的使用小结》本文主要介绍了Mavenpom.xml文件中build,plugin标签的使用小结,文中通过示例代码介绍的非常详细,对大家的学... 目录<build> 标签Plugins插件<build> 标签<build> 标签是 pom.XML

JAVA虚拟机中 -D, -X, -XX ,-server参数使用

《JAVA虚拟机中-D,-X,-XX,-server参数使用》本文主要介绍了JAVA虚拟机中-D,-X,-XX,-server参数使用,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有... 目录一、-D参数二、-X参数三、-XX参数总结:在Java开发过程中,对Java虚拟机(JVM)的启动参数进

Java中使用注解校验手机号格式的详细指南

《Java中使用注解校验手机号格式的详细指南》在现代的Web应用开发中,数据校验是一个非常重要的环节,本文将详细介绍如何在Java中使用注解对手机号格式进行校验,感兴趣的小伙伴可以了解下... 目录1. 引言2. 数据校验的重要性3. Java中的数据校验框架4. 使用注解校验手机号格式4.1 @NotBl

Python使用DeepSeek进行联网搜索功能详解

《Python使用DeepSeek进行联网搜索功能详解》Python作为一种非常流行的编程语言,结合DeepSeek这一高性能的深度学习工具包,可以方便地处理各种深度学习任务,本文将介绍一下如何使用P... 目录一、环境准备与依赖安装二、DeepSeek简介三、联网搜索与数据集准备四、实践示例:图像分类1.