摘要: 问题是这样的,jeecg分布式部署,在一台服务器中修改了 数据字典的内容,但是另一台服务器没有同步,仔细看了一下源码,原来是数据字典是缓存到内存中的,所以我们修改,使之缓存到redis中,这样可以保证两台服务器同步
1.数据字典的加载是在InitListener中,每次启动都会初始化的,如图中的方法
2.下面看一下进行缓存的代码,
3.数据字典的实体类
4.下面看一下,前台页面读取数据字典的方法
这里可以看出是在读取内存中的数据字典
显然,可以看出jeecg的数据字典 是放到静态内存中,这样就导致两台服务器不同步的问题
下面我们要解决是两个问题,一是初始化和实时缓存数据字典,二是读取redis中的数据字典的问题
1.先解决缓存的问题(此处只举例,具体代码自己实现)
还有实时缓存的代码也是一样的,实现不难
2,解决读取的问题
这个方法就是从redis中读取,并转化成实体类的方法,然后在各个方法中调用即可
这个问题同样出现在,多语言,多数据源信息 的上面,按照上面方法修改即可