- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
我已经为特定的二进制格式(nfdump 如果有人感兴趣)编写了一个解析器类,它使用了 java.nio 的 MappedByteBuffer。读取每个几 GB 的文件。二进制格式只是一系列 header 和大部分固定大小的二进制记录,通过调用 nextRecord() 将其馈送到被调用方,nextRecord() 会推送状态机,完成后返回 null。它表现良好。它在开发机器上运行。
在我的生产主机上,它可以运行几分钟或几小时,但似乎总是抛出“java.lang.InternalError: a fault occurred in a recent unsafe memory access operation in compiled Java code”,指出其中一个Map.getInt、getShort方法,即map中的读操作。
设置 map 的无争议(?)代码是这样的:
/** Set up the map from the given filename and position */
protected void open() throws IOException {
// Set up buffer, is this all the flexibility we'll need?
channel = new FileInputStream(file).getChannel();
MappedByteBuffer map1 = channel.map(FileChannel.MapMode.READ_ONLY, 0, channel.size());
map1.load(); // we want the whole thing, plus seems to reduce frequency of crashes?
map = map1;
// assumes the host writing the files is little-endian (x86), ought to be configurable
map.order(java.nio.ByteOrder.LITTLE_ENDIAN);
map.position(position);
}
然后我使用各种 map.get* 方法读取短整型、整型、长型和其他字节序列,然后到达文件末尾并关闭 map 。
我从未见过在我的开发主机上抛出的异常。但是我的生产主机和开发主机之间的重要区别在于,在前者上,我正在通过 NFS 读取这些文件的序列(最终可能为 6-8TB,仍在增长)。在我的开发机器上,我在本地选择了较小的这些文件 (60GB),但是当它在生产主机上爆炸时,通常在它达到 60GB 数据之前就已经很好了。
两台机器都运行 java 1.6.0_20-b02,尽管生产主机运行的是 Debian/lenny,开发主机是 Ubuntu/karmic。我不相信这会有什么不同。两台机器都有 16GB RAM,并使用相同的 Java 堆设置运行。
我认为,如果我的代码中存在错误,那么 JVM 中的错误就足够多了,不会向我抛出适当的异常!但我认为这只是一个特定的 JVM 实现错误,由于 NFS 和 mmap 之间的交互,可能是 6244515 的重复出现。这是官方固定的。
我已经尝试添加“加载”调用以强制 MappedByteBuffer 将其内容加载到 RAM 中——这似乎延迟了我完成的一次测试运行中的错误,但没有阻止它。也可能是巧合,这是它在坠毁前经过的最长时间!
如果您已经读到这里并且以前用 java.nio 做过这种事情,您的直觉是什么?现在我的是在没有 nio 的情况下重写它 :)
最佳答案
我会在不使用映射 NIO 的情况下重写它。如果您正在处理多个文件,则会出现映射内存永远不会释放的问题,因此您将用完虚拟内存:注意,这不一定只是与垃圾收集器交互的 OutOfMemoryError,它会是一个未能分配新的映射缓冲区。我会使用 FileChannel。
话虽如此,对 NFS 文件的大规模操作总是问题重重。您最好重新设计系统,以便每个文件都由其本地 CPU 读取。通过这种方式,您还将获得巨大的速度提升,远远超过不使用映射缓冲区所损失的 20%。
关于导致虚拟机故障的 Java 映射/nio/NFS 问题 : "a fault occurred in a recent unsafe memory access operation in compiled Java code",我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/2949371/
我正在尝试编写 Access Access 数据库的脚本,以便在命令行上使用。 Access 数据库使用工作组文件进行保护。 Dim oApp, sWGF,myWS Set sApp = Create
我有一个包含数据表的表格。我希望用户能够选择多行,单击按钮并运行一些 sql 查询并对这些行执行一些工作。 查看我的 VBA 代码,我发现如何使用 CurrentRecord 属性 Access 最后
如果我在某个网络位置有 Microsoft Access 2007 数据库,那么可以使用该数据库的客户端计算机的数量是否有限制?客户端不会安装 Access,而是使用 Access Runtime 2
我正在开发一个注册系统。但我收到此错误:You tried to execute a query that does not include the specified expression.. 我正
我有一个产品设计为使用 MS Access 文件作为数据库的桌面产品。 现在,一些用户需要将它安装在几台 PC(比如说 2 或 3 台)上并共享数据库。 我想将 MS Access 文件放在共享文件夹
我接手了一个旧的软件项目,该项目使用 MS Access 数据库来存储数据。但是数据库不会在 Access 中打开,如下所示: "You do not have the necessary permi
我有一个文件夹,里面装满了 100 多个 Access97 文件。我需要将它们全部更新到 Access2003。 我可以手动完成,但使用 VBA 可能会快很多。 有没有人会有一个片段可以做到这一点?或
我正在通过 SQL Server 迁移助手 (SSMA) 将数据从 Access 数据库迁移到 SQL Server。 Access 应用程序将继续与转换为链接表的本地表一起使用。 一个连续的表单在加
我正在通过 SQL Server 迁移助手 (SSMA) 将数据从 Access 数据库迁移到 SQL Server。 Access 应用程序将继续与转换为链接表的本地表一起使用。 一个连续的表单在加
我的公司用 Visual Basic 6 开发了一个应用程序。 该应用程序通过 ODBC 数据源使用 Access 数据库。 Access 数据库是一个扩展名为“.mdb”的文件。 在以下环境中运行应
我一直在尝试让 Microsoft Access 从主 Access 窗口中“退出”,以便我可以隐藏 Access 窗口并仅在桌面上显示表单,以便可以轻松地将其放置在其他应用程序旁边。 起初我发现了一
我想在 access 2010 中使用 access 2000 和 2003 数据库。由于我不想检查一切是否手动工作,我正在寻找一种工具来分析 VBA 代码以查找使用 access 2010 发生的错
所以我有一个 Excel 工作簿,其中有一个很好的 shaperange 对象的全局 map 。通过一些非常简单的代码,我可以更改颜色、将国家/地区集合分组和取消分组为数组等......并且效果非常好
我们希望有大约 35-40 人通过共享驱动器上的脚本写入 Access 数据库。这些指标分解为他们需要每小时写大约 3-7 次。 Access 会支持这一点而不会对我产生影响吗? 是的,我很乐意将其用
我正在寻找一种使用 VBA 代码从外部数据库文件中删除 VBA 模块的方法。名为“myfile.accdb”的外部文件有一个名为“mod1”的模块,我希望能够在单独的项目中使用 VBA 代码删除该模块
我在 Access 2003 数据库(在 Access 2007 中开发)中有三个表单,它们处于父级 -> 子级 -> 孙子级关系中。在子窗体的 'Form_Load' 子窗体中,我设置了孙子窗体的一
MS Access 2007 存在拒绝在设计模式下显示表单的问题。我可以看到表单的代码(如果我查看显示表单的按钮的事件属性),但我看不到作为 GUI 布局的表单。而且,当我尝试从应用程序的主窗口调用此
我编写了代码,使用 Excel 中的下拉列表提供的标准将两个表连接起来,然后将数据返回到电子表格上的特定位置(工作表上已经有标题)。 这在我的机器上和其他机器上使用 MS Access 的机器上都可以
我正在开始构建一个应用程序,该应用程序从给定的根路径开始遍历文件夹结构,并将所有找到的 Access 1997 .mdb 文件转换为较新的 Access 2007/2010 .accdb 格式。但是,
我有一个表单和一个按钮。我想通过单击按钮打开另一个表单,并将参数从父表单传递到子表单(子表单的 RecordSource 有参数)。我该怎么做? 最佳答案 您可以通过引用表单的对象来引用调用表单的任何
我是一名优秀的程序员,十分优秀!