hibernate中session的线程安全问题
Hibernate的基本特征是完成面向对象的程序设计语言到关系数据库的映射,在Hibernate中使用持久化对象PO(Persistent Object)完成持久化操作,对PO的操作必须在Session管理下才能同步到数据库,
但是这里的Session并非指HttpSession,可以理解为基于JDBC的Connnection,Session是 Hibernate运作的中心,
对象的生命周期、事务的管理、数据库的存取都与Session息息相关,首先,我们需要知道,
SessionFactory负责创建Session,SessionFactory是线程安全的,多个并发线程可以同时访问一个
SessionFactory 并从中获取Session实例。
而Session并非线程安全,也就是说,如果多个线程同时使用一个Session实例进行数据存取,
则将会导致 Session 数据存取逻辑混乱.因此创建的Session实例必须在本地存取空上运行,
使之总与当前的线程相关。这里就需要用到ThreadLocal,在很多种Session 管理方案中都用到了它.
ThreadLocal 是Java中一种较为特殊的线程绑定机制,通过ThreadLocal存取的数据,
总是与当前线程相关,
也就是说,JVM 为每个运行的线程,绑定了私有的本地实例存取空间,从而为多线程环境常出现的并发访问问题提供了一种隔离机制,ThreadLocal并不是线程本地化的实现,而是线程局部变量。也就是说每个使用该变量的线程都必须为该变量提供一个副本,每个线程改变该变量的值仅仅是改变该副本的值,而不会影响其他线程的该变量的值,ThreadLocal是隔离多个线程的数据共享,不存在多个线程之间共享资源,因此不再需要对线程同步。
LinkedList源码分析 (JDK1.8)
AbstractSequentialList源码分析
Vector源码分析
ArrayList简介
获取类运行
类加载器的作用
什么时候会发生类初始化
IIS无法加载字体文件(*.woff,*.svg)的解决办法
PowerDesigner 显示name(中文) 和显示code(字段名) 设置
- 最新文章
-
关于1/2 local-dirs are bad: /mnt/yarn; 1/1 log-dirs are bad: /var/log/hadoop-yarn/containers报错的问题解决 flink
shell脚本删除hbase里面的数据(按照rowkey批量删除hbase的数据)
关于在将excel数据导入到mysql数据库的时候中文变成问号的处理方式
关于做了savepoint之后改变DAG当中的算子的处理方式和遇到的错误
关于30大洋看的一篇帖子(为什么我的Flink任务正常运行,UI上却不显示接收和发送的数据条数呢?)
关于flink 程序提交到yarn上面运行的相关操作和创建checkpoint和savepoint的相关操作
关于mysqldump当中遇到的坑SET @@SESSION.SQL_LOG_BIN= 0;解决方法
关于通过Python读取hbase里面的数据通过row_prefi前缀的方式读取数据的方式
【转】常见六大Web 安全攻防解析
各大语言性能对比PK数据