从 1.9.0 版本开始,apollo-portal 增加了 session 共享支持,从而可以在集群部署 apollo-portal 时实现 session 共享。
使用方式
1. 基于 JDBC 的 session 共享(默认)
默认配置即为 基于 JDBC 的 session 共享
所以清除 session 共享相关的配置并配置数据库连接即可,需要清理的配置如下
外置配置文件(properties/yml)里面的 spring.session.store-type
配置项
环境变量里面的 SPRING_SESSION_STORE_TYPE
System Property 里面的 spring.session.store-type
数据库连接有以下几种方式设置,按照优先级从高到低分别为:
1.1 System Property
-Dspring.datasource.url=xxx
-Dspring.datasource.username=xxx
-Dspring.datasource.password=xxx
1.2 环境变量
export SPRING_DATASOURCE_URL="xxx"
export SPRING_DATASOURCE_USERNAME="xxx"
export SPRING_DATASOURCE_PASSWORD="xxx"
1.3 外部配置文件
例如 config/application-github.properties
spring.datasource.url=xxx
spring.datasource.username=xxx
spring.datasource.password=xxx
1.4 关于非 mysql 数据库初始化 session 的表
apollo 的 sql 当中的建表语句为 mysql 格式, 如果需要使用其它数据库可以参考 spring-session 提供的其它建表 sql
请根据所使用的数据库选择对应的 sql 脚本
db2.sql
derby.sql
h2.sql
hsqldb.sql
mysql.sql
oracle.sql
postgresql.sql
sqlite.sql
sqlserver.sql
sybase.sql
2. 基于 Redis 的 session 共享
有以下几种方式设置,按照优先级从高到低分别为:
注:redis 也支持集群、哨兵模式,配置方式为标准的 Spring Data Redis
模式(以 spring.redis
开头的配置项),具体方式请自行研究 Spring Data Redis
相关文档或咨询 Spring Data
Group
2.1 System Property
-Dspring.session.store-type=redis
-Dspring.redis.host=xxx
-Dspring.redis.port=xxx
-Dspring.redis.username=xxx
-Dspring.redis.password=xxx
2.2 环境变量
export SPRING_SESSION_STORE_TYPE="redis"
export SPRING_REDIS_HOST="xxx"
export SPRING_REDIS_PORT="xxx"
export SPRING_REDIS_USERNAME="xxx"
export SPRING_REDIS_PASSWORD="xxx"
2.3 外部配置文件
例如 config/application-github.properties
spring.session.store-type=redis
spring.redis.host=xxx
spring.redis.port=xxx
spring.redis.username=xxx
spring.redis.password=xxx
3. 不启用 session 共享
有以下几种方式设置,按照优先级从高到低分别为:
3.1 System Property
-Dspring.session.store-type=none
3.2 环境变量
export SPRING_SESSION_STORE_TYPE="none"
3.3 外部配置文件
例如 config/application-github.properties
spring.session.store-type=none