SpringSession集成SpringBoot实现Nginx负载均衡下的Session共享
Nginx实现负载均衡时,往往会导致Session不能共享的问题,我们可以使用 ip_hash负载均衡策略,但是这种策略的弊端很多,容易导致服务器压力过大而崩溃。这时,SpringSession实现session就是一个很好的选择。
这里是一个简单的SpringSession集成SpringBoot实现Nginx负载均衡下的Session共享的例子,只完成同域名同项目访问时的session共享
1、创建一个springboot项目并加入响应的依赖
-
pom文件
<?xml version="1.0" encoding="UTF-8"?> <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd"> <modelVersion>4.0.0</modelVersion> <parent> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-parent</artifactId> <version>2.3.2.RELEASE</version> <relativePath/> <!-- lookup parent from repository --> </parent> <groupId>org.study.springsession</groupId> <artifactId>02-springsession-springboot</artifactId> <version>1.0.0</version> <properties> <java.version>1.8</java.version> </properties> <dependencies> <!--springboot与Redis集成的起步依赖 --> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-data-redis</artifactId> </dependency> <!--SpringBoot框架web起步依赖--> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId> </dependency> <!--spring session 将数据存入Redis的依赖 --> <dependency> <groupId>org.springframework.session</groupId> <artifactId>spring-session-data-redis</artifactId> </dependency> </dependencies> <build> <plugins> <plugin> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-maven-plugin</artifactId> </plugin> </plugins> </build> </project>
2、编写Controller
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.ResponseBody;
import javax.servlet.http.HttpSession;
@Controller
public class TestController {
@RequestMapping("/set")
public @ResponseBody String setSession(HttpSession session){
session.setAttribute("data","我的Session数据");
return "设置Session成功";
}
@RequestMapping("/get")
public @ResponseBody String getSession(HttpSession session){
String data= (String) session.getAttribute("data");
return data;
}
}
3、编写springboot主配置文件
spring.redis.host=
spring.redis.port=6379
spring.redis.password=2580
#设置SpringSession的Session生命周期为30分钟
#server.servlet.session.timeout=30m
#指定Cookie的存放路径为根路径用于实现同域名不同项目的session共享
#server.servlet.session.cookie.path=/
#指定cookie的存放域名,实现同根域名不同二级子域名的session共享
#server.servlet.session.cookie.domain=myweb.com
server.port=9400
- 编写完后打包
- 打包后将server.port=9400改成server.port=9300,再次打包
- 将打包完的两个jar文件上传到linux系统
4、后台启动这两个springboot项目(需确保redis服务开启)
-
启动9300
-
启动9400
5、修改nginx配置文件
只需修改http下的这几项
upstream www.test.com {
server :9300;
server :9400;
}
server {
listen 80;
server_name localhost;
#charset koi8-r;
#access_log logs/host.access.log main;
location / {
proxy_pass http://www.test.com;
}
6、开启nginx
-
/usr/local/nginx/sbin/nginx -c /usr/local/nginx/conf/nginx.conf -t 该命令看nginx配置文件是否有错误
-
使用nginx配置文件启动nginx:/usr/local/nginx/sbin/nginx -c /usr/local/nginx/conf/nginx.conf
7、测试,在9300请求set的session在9400能被获取