阅读量:3
1、spring事务失效的几种情况?
- 自己new的对象(非spring定义的bean),或者同一个类的方法调用(this.调用,未使用动态代理),这两种方式都会绕过spring的aop
- 对应的数据库不支持事务
- 事务标记@Transational加在了非public方法上,spring aop的特性
- 抛出的是非runtimeException异常,spring aop的特性
- 事务标记的方法内部捕获了异常,未重新抛出
- 开启的子线程中
2、向redis中快速写入百万数据?
- 使用管道技术(批量发送redis命令,介绍网络通信开销)
- 拆分数据块并使用多线程,将要插入的数据分块,有多个线程并发插入
- 合理设置redis内存,避免redis内存过小,导致频繁的内存回收和分配
- 考虑暂时性暂停redis的持久化
3、一个事务方法中,有锁需要注意什么
- 注意锁粒度和锁类型的选取(共享和排他)
- 加锁和解锁时机
- 确保在事务开始后立即获取必要的锁,并在事务提交或回滚后立即释放锁。
- 避免在锁持有期间进行不必要的操作,以减少锁持有时间。
- 死锁预防
- 设计合理的加锁顺序,避免循环等待条件。
- 使用数据库提供的死锁检测和超时机制,或者在应用层面实现死锁检测和解决策略。
- 异常处理:
- 确保在捕获异常时能够正确释放持有的锁,避免资源泄露。
- 在事务回滚时,确保所有锁都被释放。