从 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

  1. -Dspring.datasource.url=xxx
  2. -Dspring.datasource.username=xxx
  3. -Dspring.datasource.password=xxx

1.2 环境变量

  1. export SPRING_DATASOURCE_URL="xxx"
  2. export SPRING_DATASOURCE_USERNAME="xxx"
  3. export SPRING_DATASOURCE_PASSWORD="xxx"

1.3 外部配置文件

例如 config/application-github.properties

  1. spring.datasource.url=xxx
  2. spring.datasource.username=xxx
  3. 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

  1. -Dspring.session.store-type=redis
  2. -Dspring.redis.host=xxx
  3. -Dspring.redis.port=xxx
  4. -Dspring.redis.username=xxx
  5. -Dspring.redis.password=xxx

2.2 环境变量

  1. export SPRING_SESSION_STORE_TYPE="redis"
  2. export SPRING_REDIS_HOST="xxx"
  3. export SPRING_REDIS_PORT="xxx"
  4. export SPRING_REDIS_USERNAME="xxx"
  5. export SPRING_REDIS_PASSWORD="xxx"

2.3 外部配置文件

例如 config/application-github.properties

  1. spring.session.store-type=redis
  2. spring.redis.host=xxx
  3. spring.redis.port=xxx
  4. spring.redis.username=xxx
  5. spring.redis.password=xxx

3. 不启用 session 共享

有以下几种方式设置,按照优先级从高到低分别为:

3.1 System Property

  1. -Dspring.session.store-type=none

3.2 环境变量

  1. export SPRING_SESSION_STORE_TYPE="none"

3.3 外部配置文件

例如 config/application-github.properties

  1. spring.session.store-type=none