您的位置:首页 > 其它

关于jeecg分布式部署时,数据字典等两台服务器不同步的问题

2018-02-28 10:46 176 查看
摘要: 问题是这样的,jeecg分布式部署,在一台服务器中修改了 数据字典的内容,但是另一台服务器没有同步,仔细看了一下源码,原来是数据字典是缓存到内存中的,所以我们修改,使之缓存到redis中,这样可以保证两台服务器同步    1.数据字典的加载是在InitListener中,每次启动都会初始化的,如图中的方法
    


    2.下面看一下进行缓存的代码,
    


    3.数据字典的实体类
    


    4.下面看一下,前台页面读取数据字典的方法
    


    这里可以看出是在读取内存中的数据字典
    显然,可以看出jeecg的数据字典 是放到静态内存中,这样就导致两台服务器不同步的问题
   下面我们要解决是两个问题,一是初始化和实时缓存数据字典,二是读取redis中的数据字典的问题
    1.先解决缓存的问题(此处只举例,具体代码自己实现)
    


    还有实时缓存的代码也是一样的,实现不难
    2,解决读取的问题



这个方法就是从redis中读取,并转化成实体类的方法,然后在各个方法中调用即可
这个问题同样出现在,多语言,多数据源信息 的上面,按照上面方法修改即可
 
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息