spring事务和synchronizd锁的问题
阅读数:86 评论数:0
跳转到新版页面分类
python/Java
正文
一、问题原因
1、由于Spring事务是通过AOP实现的。
所以在synchronized修饰的方法执行前会有开启事务,之后会有提交事务逻辑。
// 示例性代码
public static void main(String[] args) {
// 目标对象
Object target ;
Proxy.newProxyInstance(ClassLoader.getSystemClassLoader(), Main.class, new InvocationHandler() {
@Override
public Object invoke(Object proxy, Method method, Object[] args) throws Throwable {
// 但凡带有@Transcational注解的方法都会被拦截
// 1... 开启事务
method.invoke(target);
// 2... 提交事务
return null;
}
});
}
2、而synchronized代码块执行是在事务之内执行的。
在syncrhonized代码块执行完时,事务还未提交,其他线程进入synchronized代码块后,读取的库数据不是最新的,所以会出问题。
二、解决方法
把synchonized修饰的级别向上提一级,这样synchronized锁的范围大于事务控制的范围。
相关推荐
一、概述
1、事务
事务就是一组操作数据库的动作集合,集合中的动作要么全部执行,要么全部不执行。
2、事务特点(ACID)
Atomicity 原子性
整个事务是一个整体,是不可分割的最小工作单
(1)Spring MVC是一个基于DispatcherServlet的MVC框架,DispatcherServlet是继承自HttpServlet的。Spring的IOC和AOP主要就用了java的
方式1:通过@PostConstruct和@PreDestroy方法。
从Java EE5开始,Servlet增加了两个影响Servlet生命周期的注解。
方式2:通
一、概述
1、spring容器
spring中有三种bean容器:BeanFactory、ApplicationContext、WebApplicationContext。
(1)BeanFactor
有时我们在做开发的时候需要记录每个任务执行时间,或者记录一段代码执行时间,最简单的方法就是打印当前时间与执行完时间的差值,然后这样如果执行大量测试的话就很麻烦,并且不直观,如果想对执行的时间做进
一、request uri部分 @PathVariable
获取路径参数,形如url/{id}
二、request header部分 @RequestHeade
一、概述
springboot中有两种方式使用kafka时,直接使用kafka-client连接kafka服务;另一种是使用spring-kafka框架来连接kafka。
1、版本兼容
使用时要注意版