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的

如果一个类交张spring管理,比如 &lt;bean id="foo1" class="demo.scope.foo" /&gt; 不指明scope就是单例。</p

@PathParam的声明允许你在URI路径中去映射你的方法将使用的参数。 @Path("/library") pu

方式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、版本兼容 使用时要注意版

当然可以自己写redis的工具类,或者使用第三方开源jar包或代码,这里使用spring boot的集成类。 一、pom依赖 <dependency> <gro