最新版分库分表集成示例 nacos配置文件
This commit is contained in:
parent
9358acb84c
commit
cf1eef7447
|
@ -400,27 +400,18 @@ public class LoginController {
|
||||||
* @return
|
* @return
|
||||||
*/
|
*/
|
||||||
private Result<JSONObject> userInfo(SysUser sysUser, Result<JSONObject> result) {
|
private Result<JSONObject> userInfo(SysUser sysUser, Result<JSONObject> result) {
|
||||||
String syspassword = sysUser.getPassword();
|
|
||||||
String username = sysUser.getUsername();
|
String username = sysUser.getUsername();
|
||||||
|
String syspassword = sysUser.getPassword();
|
||||||
// 获取用户部门信息
|
// 获取用户部门信息
|
||||||
JSONObject obj = new JSONObject();
|
JSONObject obj = new JSONObject(new LinkedHashMap<>());
|
||||||
List<SysDepart> departs = sysDepartService.queryUserDeparts(sysUser.getId());
|
|
||||||
obj.put("departs", departs);
|
// 生成token
|
||||||
if (departs == null || departs.size() == 0) {
|
String token = JwtUtil.sign(username, syspassword);
|
||||||
obj.put("multi_depart", 0);
|
// 设置token缓存有效时间
|
||||||
} else if (departs.size() == 1) {
|
redisUtil.set(CommonConstant.PREFIX_USER_TOKEN + token, token);
|
||||||
sysUserService.updateUserDepart(username, departs.get(0).getOrgCode());
|
redisUtil.expire(CommonConstant.PREFIX_USER_TOKEN + token, JwtUtil.EXPIRE_TIME * 2 / 1000);
|
||||||
obj.put("multi_depart", 1);
|
obj.put("token", token);
|
||||||
} else {
|
|
||||||
//查询当前是否有登录部门
|
|
||||||
// update-begin--Author:wangshuai Date:20200805 for:如果用戶为选择部门,数据库为存在上一次登录部门,则取一条存进去
|
|
||||||
SysUser sysUserById = sysUserService.getById(sysUser.getId());
|
|
||||||
if(oConvertUtils.isEmpty(sysUserById.getOrgCode())){
|
|
||||||
sysUserService.updateUserDepart(username, departs.get(0).getOrgCode());
|
|
||||||
}
|
|
||||||
// update-end--Author:wangshuai Date:20200805 for:如果用戶为选择部门,数据库为存在上一次登录部门,则取一条存进去
|
|
||||||
obj.put("multi_depart", 2);
|
|
||||||
}
|
|
||||||
// update-begin--Author:sunjianlei Date:20210802 for:获取用户租户信息
|
// update-begin--Author:sunjianlei Date:20210802 for:获取用户租户信息
|
||||||
String tenantIds = sysUser.getRelTenantIds();
|
String tenantIds = sysUser.getRelTenantIds();
|
||||||
if (oConvertUtils.isNotEmpty(tenantIds)) {
|
if (oConvertUtils.isNotEmpty(tenantIds)) {
|
||||||
|
@ -438,13 +429,26 @@ public class LoginController {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
// update-end--Author:sunjianlei Date:20210802 for:获取用户租户信息
|
// update-end--Author:sunjianlei Date:20210802 for:获取用户租户信息
|
||||||
// 生成token
|
|
||||||
String token = JwtUtil.sign(username, syspassword);
|
|
||||||
// 设置token缓存有效时间
|
|
||||||
redisUtil.set(CommonConstant.PREFIX_USER_TOKEN + token, token);
|
|
||||||
redisUtil.expire(CommonConstant.PREFIX_USER_TOKEN + token, JwtUtil.EXPIRE_TIME * 2 / 1000);
|
|
||||||
obj.put("token", token);
|
|
||||||
obj.put("userInfo", sysUser);
|
obj.put("userInfo", sysUser);
|
||||||
|
|
||||||
|
List<SysDepart> departs = sysDepartService.queryUserDeparts(sysUser.getId());
|
||||||
|
obj.put("departs", departs);
|
||||||
|
if (departs == null || departs.size() == 0) {
|
||||||
|
obj.put("multi_depart", 0);
|
||||||
|
} else if (departs.size() == 1) {
|
||||||
|
sysUserService.updateUserDepart(username, departs.get(0).getOrgCode());
|
||||||
|
obj.put("multi_depart", 1);
|
||||||
|
} else {
|
||||||
|
//查询当前是否有登录部门
|
||||||
|
// update-begin--Author:wangshuai Date:20200805 for:如果用戶为选择部门,数据库为存在上一次登录部门,则取一条存进去
|
||||||
|
SysUser sysUserById = sysUserService.getById(sysUser.getId());
|
||||||
|
if(oConvertUtils.isEmpty(sysUserById.getOrgCode())){
|
||||||
|
sysUserService.updateUserDepart(username, departs.get(0).getOrgCode());
|
||||||
|
}
|
||||||
|
// update-end--Author:wangshuai Date:20200805 for:如果用戶为选择部门,数据库为存在上一次登录部门,则取一条存进去
|
||||||
|
obj.put("multi_depart", 2);
|
||||||
|
}
|
||||||
obj.put("sysAllDictItems", sysDictService.queryAllDictItems());
|
obj.put("sysAllDictItems", sysDictService.queryAllDictItems());
|
||||||
result.setResult(obj);
|
result.setResult(obj);
|
||||||
result.success("登录成功");
|
result.success("登录成功");
|
||||||
|
@ -588,9 +592,9 @@ public class LoginController {
|
||||||
return Result.ok();
|
return Result.ok();
|
||||||
}
|
}
|
||||||
/**
|
/**
|
||||||
* 登录二维码
|
* 获取登录二维码
|
||||||
*/
|
*/
|
||||||
@ApiOperation(value = "登录二维码", notes = "登录二维码")
|
@ApiOperation(value = "获取登录二维码", notes = "获取登录二维码")
|
||||||
@GetMapping("/getLoginQrcode")
|
@GetMapping("/getLoginQrcode")
|
||||||
public Result<?> getLoginQrcode() {
|
public Result<?> getLoginQrcode() {
|
||||||
String qrcodeId = CommonConstant.LOGIN_QRCODE_PRE+IdWorker.getIdStr();
|
String qrcodeId = CommonConstant.LOGIN_QRCODE_PRE+IdWorker.getIdStr();
|
||||||
|
@ -621,7 +625,7 @@ public class LoginController {
|
||||||
/**
|
/**
|
||||||
* 获取用户扫码后保存的token
|
* 获取用户扫码后保存的token
|
||||||
*/
|
*/
|
||||||
@ApiOperation(value = "获取用户扫码后保存的token", notes = "获取用户扫码后保存的token")
|
@ApiOperation(value = "获取用户扫码后Token", notes = "获取用户扫码后Token")
|
||||||
@GetMapping("/getQrcodeToken")
|
@GetMapping("/getQrcodeToken")
|
||||||
public Result getQrcodeToken(@RequestParam String qrcodeId) {
|
public Result getQrcodeToken(@RequestParam String qrcodeId) {
|
||||||
Object token = redisUtil.get(CommonConstant.LOGIN_QRCODE_TOKEN + qrcodeId);
|
Object token = redisUtil.get(CommonConstant.LOGIN_QRCODE_TOKEN + qrcodeId);
|
||||||
|
|
|
@ -0,0 +1,59 @@
|
||||||
|
spring:
|
||||||
|
shardingsphere:
|
||||||
|
datasource:
|
||||||
|
names: ds0,ds1
|
||||||
|
ds0:
|
||||||
|
driverClassName: com.mysql.cj.jdbc.Driver
|
||||||
|
url: jdbc:mysql://jeecg-boot-mysql:3306/jeecg-boot?useSSL=false&useUnicode=true&characterEncoding=utf-8&serverTimezone=Asia/Shanghai
|
||||||
|
type: com.alibaba.druid.pool.DruidDataSource
|
||||||
|
username: root
|
||||||
|
password: root
|
||||||
|
ds1:
|
||||||
|
driverClassName: com.mysql.cj.jdbc.Driver
|
||||||
|
url: jdbc:mysql://jeecg-boot-mysql:3306/jeecg-boot2?useSSL=false&useUnicode=true&characterEncoding=utf-8&serverTimezone=Asia/Shanghai
|
||||||
|
type: com.alibaba.druid.pool.DruidDataSource
|
||||||
|
username: root
|
||||||
|
password: root
|
||||||
|
props:
|
||||||
|
sql-show: true
|
||||||
|
rules:
|
||||||
|
replica-query:
|
||||||
|
load-balancers:
|
||||||
|
round-robin:
|
||||||
|
type: ROUND_ROBIN
|
||||||
|
props:
|
||||||
|
default: 0
|
||||||
|
data-sources:
|
||||||
|
prds:
|
||||||
|
primary-data-source-name: ds0
|
||||||
|
replica-data-source-names: ds1
|
||||||
|
load-balancer-name: round_robin
|
||||||
|
sharding:
|
||||||
|
binding-tables:
|
||||||
|
- sys_log
|
||||||
|
key-generators:
|
||||||
|
snowflake:
|
||||||
|
type: SNOWFLAKE
|
||||||
|
props:
|
||||||
|
worker-id: 123
|
||||||
|
sharding-algorithms:
|
||||||
|
table-classbased:
|
||||||
|
props:
|
||||||
|
strategy: standard
|
||||||
|
algorithmClassName: org.jeecg.modules.test.sharding.algorithm.StandardModTableShardAlgorithm
|
||||||
|
type: CLASS_BASED
|
||||||
|
database-inline:
|
||||||
|
type: INLINE
|
||||||
|
props:
|
||||||
|
algorithm-expression: ds$->{operate_type % 2}
|
||||||
|
tables:
|
||||||
|
sys_log:
|
||||||
|
actual-data-nodes: ds$->{0..1}.sys_log$->{0..1}
|
||||||
|
database-strategy:
|
||||||
|
standard:
|
||||||
|
sharding-column: operate_type
|
||||||
|
sharding-algorithm-name: database-inline
|
||||||
|
table-strategy:
|
||||||
|
standard:
|
||||||
|
sharding-algorithm-name: table-classbased
|
||||||
|
sharding-column: log_type
|
|
@ -0,0 +1,33 @@
|
||||||
|
spring:
|
||||||
|
shardingsphere:
|
||||||
|
datasource:
|
||||||
|
names: ds0
|
||||||
|
ds0:
|
||||||
|
driverClassName: com.mysql.cj.jdbc.Driver
|
||||||
|
url: jdbc:mysql://jeecg-boot-mysql:3306/jeecg-boot?useSSL=false&useUnicode=true&characterEncoding=utf-8&serverTimezone=Asia/Shanghai
|
||||||
|
username: root
|
||||||
|
password: root
|
||||||
|
type: com.alibaba.druid.pool.DruidDataSource
|
||||||
|
props:
|
||||||
|
sql-show: true
|
||||||
|
rules:
|
||||||
|
sharding:
|
||||||
|
binding-tables: sys_log
|
||||||
|
key-generators:
|
||||||
|
snowflake:
|
||||||
|
type: SNOWFLAKE
|
||||||
|
props:
|
||||||
|
worker-id: 123
|
||||||
|
sharding-algorithms:
|
||||||
|
table-classbased:
|
||||||
|
props:
|
||||||
|
strategy: standard
|
||||||
|
algorithmClassName: org.jeecg.modules.test.sharding.algorithm.StandardModTableShardAlgorithm
|
||||||
|
type: CLASS_BASED
|
||||||
|
tables:
|
||||||
|
sys_log:
|
||||||
|
actual-data-nodes: ds0.sys_log$->{0..1}
|
||||||
|
table-strategy:
|
||||||
|
standard:
|
||||||
|
sharding-algorithm-name: table-classbased
|
||||||
|
sharding-column: log_type
|
|
@ -35,6 +35,7 @@ public class JeecgShardingDemoController extends JeecgController<ShardingSysLog,
|
||||||
@PostMapping(value = "/test1")
|
@PostMapping(value = "/test1")
|
||||||
@ApiOperation(value = "单库分表插入", notes = "单库分表")
|
@ApiOperation(value = "单库分表插入", notes = "单库分表")
|
||||||
public Result<?> add() {
|
public Result<?> add() {
|
||||||
|
log.info("---------------------------------单库分表插入--------------------------------");
|
||||||
int size = 10;
|
int size = 10;
|
||||||
for (int i = 0; i < size; i++) {
|
for (int i = 0; i < size; i++) {
|
||||||
ShardingSysLog shardingSysLog = new ShardingSysLog();
|
ShardingSysLog shardingSysLog = new ShardingSysLog();
|
||||||
|
@ -43,7 +44,7 @@ public class JeecgShardingDemoController extends JeecgController<ShardingSysLog,
|
||||||
shardingSysLog.setOperateType(i);
|
shardingSysLog.setOperateType(i);
|
||||||
shardingSysLogService.save(shardingSysLog);
|
shardingSysLogService.save(shardingSysLog);
|
||||||
}
|
}
|
||||||
return Result.OK();
|
return Result.OK("单库分表插入10条数据完成!");
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -57,30 +58,30 @@ public class JeecgShardingDemoController extends JeecgController<ShardingSysLog,
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 双库分表 - 插入
|
* 分库分表 - 插入
|
||||||
* @return
|
* @return
|
||||||
*/
|
*/
|
||||||
@PostMapping(value = "/test2")
|
@PostMapping(value = "/test2")
|
||||||
@ApiOperation(value = "双库分表插入", notes = "双库分表")
|
@ApiOperation(value = "分库分表插入", notes = "分库分表")
|
||||||
public Result<?> test2() {
|
public Result<?> test2() {
|
||||||
int start=20;
|
int start=20;
|
||||||
int size=30;
|
int size=50;
|
||||||
for (int i = start; i <= size; i++) {
|
for (int i = start; i <= size; i++) {
|
||||||
ShardingSysLog shardingSysLog = new ShardingSysLog();
|
ShardingSysLog shardingSysLog = new ShardingSysLog();
|
||||||
shardingSysLog.setLogContent("双库分表测试");
|
shardingSysLog.setLogContent("分库分表测试");
|
||||||
shardingSysLog.setLogType(i);
|
shardingSysLog.setLogType(0);
|
||||||
shardingSysLog.setOperateType(i);
|
shardingSysLog.setOperateType(i);
|
||||||
shardingSysLogService.save(shardingSysLog);
|
shardingSysLogService.save(shardingSysLog);
|
||||||
}
|
}
|
||||||
return Result.OK();
|
return Result.OK("分库分表插入10条数据完成!");
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 双库分表 - 查询
|
* 分库分表 - 查询
|
||||||
* @return
|
* @return
|
||||||
*/
|
*/
|
||||||
@PostMapping(value = "/list2")
|
@PostMapping(value = "/list2")
|
||||||
@ApiOperation(value = "双库分表查询", notes = "双库分表")
|
@ApiOperation(value = "分库分表查询", notes = "分库分表")
|
||||||
public Result<?> list2() {
|
public Result<?> list2() {
|
||||||
return Result.OK(shardingSysLogService.list());
|
return Result.OK(shardingSysLogService.list());
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,6 +1,6 @@
|
||||||
server:
|
server:
|
||||||
#微服务端口
|
|
||||||
port: 7001
|
port: 7001
|
||||||
|
|
||||||
spring:
|
spring:
|
||||||
application:
|
application:
|
||||||
name: jeecg-system
|
name: jeecg-system
|
||||||
|
|
Loading…
Reference in New Issue