各种疑难杂症记录

分布式数据库问题处理

背景

线上环境因为数据库压力比较大,所以使用了分布式数据库进行减轻压力,实现方式是使用主从mysql数据库

问题

更新和插入的数据,在接下来的业务处理查询不到

原因

更新,插入,查询 在分布式数据库中不是顺序执行,在主数据库中操作后,需要同步到从数据库,从数据库的数据没有强一直性.

解决

总结了三个解决方案:
1.使用事务管理:在需要保证数据一致性的地方,加上事务
2.线程睡眠:在查询前,等待一秒,让更新或插入的数据,在主从数据库之间同步
3.指定主数据库:对于数据具有强一致性需求的业务,需要指定使用主数据库

PageHelper在没使用分页的地方进行分页

背景

框架使用Springboot Springcloud mybatis tk.mybatis PageHelper

问题

最近在项目中出现很奇怪的现象,没有进行业务的sql自动进行了分页

原因

1.PageHelper分页插件使用ThreadLocal和拦截器实现分页
2.在项目中,使用了线程池管理线程;线程会被重复使用,ThreadLocal是在线程的维度上进行数据的维护…
3.项目中使用PageHelper.startPage(int pageNum, int pageSize)会将分页信息保存到线程中(ThreadLocal),拦截器拦截到查询的sql时,会从线程中获取(ThreadLocal)分页信息进行分页操作,在操作的最后会清空线程信息
4.如果使用了PageHelper.startPage(int pageNum, int pageSize),但是没有使用查询,那么下一个业务拿到该线程进行操作的时候,在进入sql拦截器的时候,会获取上一个业务保存起来的业务信息,进行分页

解决

在使用了分页插件后,马上进行sql的查询

        PageHelper.startPage(1, 10);
        List<Object> leaveApplies = leaveApplyMapper.selectByExample(example);

生命式事务不生效

原理参考:https://blog.csdn.net/qq_20597727/article/details/84900994?depth_1-utm_source=distribute.pc_relevant.none-task&utm_source=distribute.pc_relevant.none-task

你可能感兴趣的:(遇到的问题)