当前位置: 首页 > news >正文

太原做网站制作wordpress怎么使用阿里图标

太原做网站制作,wordpress怎么使用阿里图标,网站权重数据包,辽宁模板网站建设公司记Mybaits缓存踩的坑 1.问题提出 最近开发一个记录操作前后修改内容的功能#xff0c;获取修改前数据比较简单#xff0c;直接从数据库获取#xff0c;记录修改后的功能也比较简单#xff0c;直接将用户修改的内容封装成po对象#xff0c;然后两个比对就可以了#xff…记Mybaits缓存踩的坑 1.问题提出 最近开发一个记录操作前后修改内容的功能获取修改前数据比较简单直接从数据库获取记录修改后的功能也比较简单直接将用户修改的内容封装成po对象然后两个比对就可以了问题就出在这。 2.场景复现 下面是出现问题的代码简化版操作分为用户端和管理端 用户端 public class UserServiceImpl{Autowiredprivate IUserDao userDao;Autowiredprivate IUserLogDao dao;Autowiredprivate StreamAction action;OverrideTransactionalpublic void modifyUser(UserDto dto){Long id dto.getUserId;//修改前的beanUserBean beforeBean userDao.queryUser(id);//修改后的beanBeanUtils.copyProperties(dto,beforeBean);//更新和用户有关的内容//....用户信息填充 UserLogBean userLogBean//这里需要修改和用户关联的记录所以插入一次userDao.insert(userLogBean);//用户端操作流action.request(beforeBean);} }StreamAction.request Override Transactional public void request(UserBean userBean){/*** 获取数据库原内容*/UserBean afterBean userDao.queryUser(id);//比对返回修改内容ModifyBean bean modify(userBean,afterBean);//...其他 业务//插入修改后的内容userBeanModifyDao.insert(bean); }此时去查看数据内添加的内容可以看到修改的部分被正确的比对出来了。 管理端 public class UserServiceImpl{Autowiredprivate IUserDao userDao;Autowiredprivate IUserLogDao dao;Autowiredprivate StreamActionManager action;OverrideTransactionalpublic void modifyUser(UserDto dto){Long id dto.getUserId;//修改前的beanUserBean beforeBean userDao.queryUser(id);//修改后的beanBeanUtils.copyProperties(dto,beforeBean);//更新和用户有关的内容//....用户信息填充 UserLogBean userLogBean//管理端操作流action.request(beforeBean);} }StreamActionManager.request Override Transactional public void request(UserBean userBean){/*** 获取数据库原内容*/UserBean afterBean userDao.queryUser(id);//比对返回修改内容ModifyBean bean modify(userBean,afterBean);//...其他 业务//插入修改后的内容userBeanModifyDao.insert(bean); }此时我们去数据库查看内容你就惊奇发现并没有见到修改的内容。不对啊我们确实已经修改过了那为什么数据库里不显示呢 3.发现问题 带着疑问我们很容易的想到是不是两个对象内容一模一样带着疑问我们尝试着打印一下用户端和管理端在进行比对前的两个对象内容 public void request(UserBean userBean){/*** 获取数据库原内容*/UserBean afterBean userDao.queryUser(id);System.out.println(userBean); System.out.println(afterBean); //比对返回修改内容ModifyBean bean modify(userBean,afterBean);//...... }用户端 我们在比对修改内容前打印两个bean结果如下 cn.example.core.core.bean.UserBean5e5a2b74 cn.example.core.core.bean.UserBean5e5a2b75两个bean不是同一个对象符合我们的预期所以用户端正确入库。 我们再来看管理端 管理端 管理端执行结果 cn.example.core.core.bean.UserBean5e5a2b77 cn.example.core.core.bean.UserBean5e5a2b77oi我们惊奇的发现这两个对象是一样的那就奇了怪了用户端和管理端业务代码甚至基本都一样的为什么会造成这个原因呢我们再输出这两个对象的内容 System.out.println(userBean.toString()); System.out.println(afterBean.toString());很惊奇的是这两个对象内容都是修改过的内容也就是service内通过BeanUtils属性赋值过的内容那我们mysql里的内容去哪了我们明明还没更新啊我们赶紧去数据库看一眼发现数据库里并没更新。数据库里内容没更新业务里的bean已经被更新过了这是为什么 4.排查问题 我们找到出现问题的原因了是因为管理端两个对象一样。那为什么会一样呢 我们在业务逻辑里很容易想到类似的场景比如我们在使用redis的时候当redis内有数据时我们希望走redis返回结果而不是走数据库以提高查询性能那会不会两个对象一样也是走了缓存呢我们通过查询数据库我们知道mysql的查询也会存在缓存但是按道理来说我们最后的结果应该是mysql的内容应该不会是后面的内容。所以只有一种情况是mybaits的缓存。 5.寻找答案 我们已经确定了是mybaits的缓存导致的问题但是为什么管理端和用户端还不一样呢为什么用户端就没有这个问题呢 我们百度之后发现mybaits有一、二级缓存之分二级缓存默认不开启。 哎会不会是用户端的缓存过期了因为用户端的有一个插入其他表的操作肯定比管理端慢对对一定是这个问题好我们去找度娘度娘说缓存没有过期时间。好好好这样玩好好好。 那么问题是什么我们已经确定不是过期时间的问题了那我们现在想的就是缓存过期也就是缓存失效了我们换个方法去查找内容“mybatis缓存失效的原因”我们找到以下结果 1.不在同一个sqlSession中 2.如果是增删改操作程序会clear缓存。 3.一级缓存未开启 4.手动清空缓存数据调用sqlsession.clearCache(). 5.更改查询条件我们一点点往下看 不在同一个sqlSession中 同一个事务内会复用同一个sqlSession。 具体我们查看控制台可以看到第一个sql执行之前会有一句话 Creating a new SqlSession Registering transaction synchronization for SqlSession [org.apache.ibatis.session.defaults.DefaultSqlSession3663af34]在之后的sql执行时会有一句话 Fetched SqlSession [org.apache.ibatis.session.defaults.DefaultSqlSession3663af34] from current transaction都是同一个sqlSession 我们业务层面的代码是在同一个事务里因为没有设置事物传播机制虽然有两个事物注解但是最后都在同一个事务那可以用 String txName TransactionSynchronizationManager.getCurrentTransactionName();查看会发现事务没有失效且都在一个事物内显然不是这个原因。 如果是增删改操作程序会clear缓存。 我们用户端涉及的增删改是另外一张表的排除 一级缓存未开启 显然开启了不然不会有这篇博客 4、5不用看了都不符合 我们分析完了仍然没找到原因。那么问题到底在哪呢 目前最有可能的就是2但是我们明明更改的是其他表啊那么不妨我们就试试改其他表。 Test Transactional //这里的事务一定要加mybatis的缓存存在条件就是需要有事务否则你查询会发现两个对象怎么样都不会相同 public void test(){UserBean beforeBean userDao.queryUser(id);//更新userLogDao.update(1,1);UserBean afterBean userDao.queryUser(id);System.out.println(beforeBean); System.out.println(afterBean); }哎神奇两个对象不一样了缓存失效了所以问题就在这所以这就是造成这个bug的原因知道了问题那我们就开始做解决方案 6.解决方案 解决方案有一下几种 关闭mybatis一级缓存无法关闭只能修改状态 mybatis:configuration:cache-enabled: false #禁用二级缓存local-cache-scope: statement #一级缓存指定为statement级别 默认为session级别使用不同的对象传递 在传递前后bean的时候用其他的bean赋值传递。 使用不同的查询方式拼接条件等使用不同的事物隔离级别sqlSession是依赖于mysql的事物所以如果数据库不支持事物那么Spring的事物 也不会生效。我们可以使用不同的事物隔离级别以创建不同的sqlSessio此时就不存在bean不同的问题 OverrideTransactionalpublic void modifyUser(UserDto dto){Long id dto.getUserId;//修改前的beanUserBean beforeBean userDao.queryUser(id);//修改后的beanBeanUtils.copyProperties(dto,beforeBean);//更新和用户有关的内容//....用户信息填充 UserLogBean userLogBean//管理端操作流action.request(beforeBean);}//另外一个类的request方法OverrideTransactional(propagation Propagation.REQUIRES_NEW)public void request(UserBean userBean){/*** 获取数据库原内容*/UserBean afterBean userDao.queryUser(id);//比对返回修改内容ModifyBean bean modify(userBean,afterBean);//...其他 业务//插入修改后的内容userBeanModifyDao.insert(bean);} 使用不同的事物传播机制我们可以看到控制台创建了两个sqlSession Creating a new SqlSession Registering transaction synchronization for SqlSession [org.apache.ibatis.session.defaults.DefaultSqlSession7488c183]//.... Creating a new SqlSession Registering transaction synchronization for SqlSession [org.apache.ibatis.session.defaults.DefaultSqlSession4797023d]//再次比较两个bean cn.example.core.core.bean.UserBean4b86a656 cn.example.core.core.bean.UserBean4c3c31a5到此为止我们的问题就解决了。
http://www.huolong8.cn/news/214822/

相关文章:

  • 抖音做我女朋友的网站微信的微网站模板下载
  • 截获网站流量怎么做医院网站管理办法
  • 一般网站的后台怎么做的国外网站注册
  • 温州网站建设公司哪个好做营销策划要用到哪些网站
  • 百度站长网站验证网站seo检测
  • 合肥官方网站建设深圳网站建设运营
  • 哈尔滨专业网站营销cms 企业
  • 网站开发代码wordpress开发者手册
  • 淘宝网站是哪个公司做的wordpress为艾迪
  • 公司网站建设哪里好外包手工活在哪里拿货
  • 国外建站网一对一直播app开发定制
  • wordpress图片站教程python建设电子商务网站
  • 汕头市城市建设总公司网站5g创业网站建设
  • 企业网站的职能主要有建设银行网上银行
  • 做网站职业咋样网站制作主题
  • 企业建网站的工作个人网站做淘宝客会怎样
  • 网站规划建设心得与体会小程序运营推广公司
  • 京东商城网站首页在线营销推广
  • 诸暨城乡与建设局网站软件开发专业的大学
  • 郑州网站建设定制开发建站工具帝国
  • 甘肃 网站建设网站域名后缀代表什么意思
  • 广东网站建设联系信息类网站怎么做
  • 天津网站建设哪家公司好服务器里怎么建设网站
  • 西安免费做网站电话湛江网站建站建设
  • 深圳手机报价网站大数据技术就业前景
  • 分类目录网站平台图书馆网站建设论文
  • 上海seo网站设计wordpress theme for free green
  • 网站留言发送到邮箱做行业网站赚钱吗
  • 青海高等级公路建设管理局网站app推广联盟平台
  • 东莞网站建设管理东莞专业网站制作设计