- Java 双重比较
- java - 比较器与 Apache BeanComparator
- Objective-C 完成 block 导致额外的方法调用?
- database - RESTful URI 是否应该公开数据库主键?
我有一个应用程序使用 EJB 3.0 和 Hibernate 在 JBoss 4.2.3 AS 上运行,事务由 EJB 控制。
我遇到的问题是 Postgres 日志中有几条关于大对象的消息,例如“错误:无效的大对象描述符:0”,有时还有“错误:大对象 488450 不存在”。结果是在应用程序中一切正常,但有时(并非总是)Postgres 无法在 hibernate 提交后提交事务(在主 EJB 中的所有代码调用的方法被执行之后)。
我调查了遗留代码并找到了代表数据库中文件存储的所有实体的父类(super class)。在此类中,文件由 Blob 属性表示,并由 getBinaryStream() 方法使用。我发现奇怪的是这个类的 finalize() 方法中的内容如下:
@Lob
@Basic(fetch = FetchType.LAZY)
@Column(name = "BIN_CONTENT", nullable = true, updatable = true)
protected Blob content;
@Override
protected void finalize() throws Throwable {
if (this.content != null) {
try {
IOUtils.closeQuietly(this.content.getBinaryStream());
} catch (Exception e) {
logger.severe("Error finalizing Blob stream");
}
try {
this.content.free();
} catch (AbstractMethodError e) {
} catch (SQLFeatureNotSupportedException e) {
} catch (UnsupportedOperationException e) {
} catch (Throwable e) {
logger.severe("Error finalizing Blob stream");
}
this.content = null;
}
super.finalize();
}
在我评论这段代码后,一切似乎都运行良好。问题是:那有必要吗?我想了解由于执行导致数据库端错误的代码内部发生了什么。
最佳答案
您提供的代码存在几个问题。
第一个问题是finalize()
时机。
java.sql.Blob
实现取决于 jdbc 驱动程序,通常实现类仅存储 blob 的标识符以及访问内容的时间(使用 getBinaryStream()
例如)执行另一个对数据库的调用。这意味着在 getBinaryStream()
被调用的那一刻,用于获取 blob 的连接应该仍然打开。但是 JVM 在调用 finalize 时不提供任何保证,因此在 finalize 中访问 Blob 是不正确的。
我不确定 PostgreSQL jdbc 驱动程序是否将此逻辑用于 blob,但我确定 java.sql.Array
实现具有此限制(即您不能调用数组的方法连接关闭后)。
第二个问题是,尽管 blob 映射被定义为惰性映射,即使客户端不使用它,blob 字段也将始终由 finalize()
加载。
通常,在使用 blob 时,客户端有责任执行清理。 blob 的使用模式是:
try {
blob = entity.getContent();
// ... use blob
} finally {
// ... do blob cleanup
}
关于java - Hibernate 和 Postgres 大对象 - 在实体 finalize() 方法中释放 Blob 资源,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/19452614/
有人告诉我,如果我只有一个“东西”,比如家(不是多个家),我应该在 routes.rb 中使用资源 :home,而不是资源 :home。但是当我查看路由时,POST 函数似乎想要 home#creat
Activity 开始。这些代码框架顺利通过。 // Initialize array adapters. One for already paired devices and //
资源 search-hadoop.com search-hadoop.com索引所有邮件列表,非常适合历史搜索。当你遇到问题时首先在这里搜索,因为很可能有人已经遇到了你的问题。 邮件列表 在A
我是 WPF 的新手,正在努力使用位于单独程序集中的样式。这就是我正在做的:- 我有一个带有\Themes 文件夹的类库项目,其中包含一个“generic.xaml”,它合并了\Themes 内的子文
我正在编写一个使用虚拟树状文件结构的插件。基本上它就像一个包含文件的标准文件系统,区别在于这些文件实际上并不存在于文件系统中的特定位置,而只是 java 对象。 这些当前由使用 SettingProv
如果我在 XAML 中使用以下内容,我会收到错误消息: 错
我正在使用 laravel 资源来获取 api 的数据: return [ 'id' => $this->id, 'unread' =>
我有以下 pom.xml: 4.0.0 mycompany resource-fail 0.0.1-SNAPSHOT BazBat
许多GDI +类都实现IDisposable,但是我不确定何时应该调用Dispose。对于使用new或静态方法(例如Graphics.CreateGraphics)创建的实例来说,这很明显。但是,由属
我正在构建一组 RESTful 资源,其工作方式如下:(我将使用“people”作为示例): 获取/people/{key} - 返回一个人对象 (JSON) GET/people?first_nam
已关闭。此问题不符合Stack Overflow guidelines 。目前不接受答案。 要求我们推荐或查找工具、库或最喜欢的场外资源的问题对于 Stack Overflow 来说是偏离主题的,因为
我有一个使用 $resource 的简单 Controller : var Regions = $resource('mocks/regions.json'); $scope.regions =
在 Azure 门户中,如何查看不同资源之间的依赖关系。我特别想查看哪些资源正在使用我要删除的存储。 最佳答案 您可以使用应用程序洞察应用程序 map 来执行此操作: 您还可以打开存储帐户的日志记录:
我正在使用 ionic 生成资源(图标和启动画面)。我正在使用 ionic v2.1.0 和 cordova v6.4.0。 到目前为止我一直在使用(它在以前的版本中工作): cordova plat
是否可以使用 Assets 包含子文件夹中的文件? 示例:[base_url]/assets/css/pepper-grinder/jquery-ui-1.8.11.custom.min.css 最佳
我正在阅读一些尝试教授 Android 开发的书。在书中,作者概述了 res/下的一些目录。他提到 res/menu 包含基于 XML 的菜单规范。他还提到了保存“通用文件”的 res/raw。当我创
关闭。这个问题是opinion-based 。目前不接受答案。 想要改进这个问题吗?更新问题,以便 editing this post 可以用事实和引文来回答它。 . 已关闭 9 年前。 Improv
我在服务器上使用 express-resource。在我的 AngularJS Controller 中: var User = $resource('/services/users/:use
因此,每当我运行我的应用程序时,它都会立即崩溃并给出以下错误: No package identifier when getting value for resource number 0x00000
对于我正在创建的(网络)应用程序,我需要使用基本身份验证在我的 UIWebView 中加载页面。 现在设置我使用的授权 header : NSString *result = [NSString st
我是一名优秀的程序员,十分优秀!