java - 在程序文件夹中创建锁定文件会导致异常

标签 java locking file-permissions h2

我最近决定为我的 Java 应用程序使用官方安装程序。

应用程序将其自身安装在程序文件下的相应文件夹中。

在我的应用程序的 jar 所在的 bin 文件夹内,我有一个 h2.db 文件,其中包含应用程序读取的一堆信息。

当我尝试在安装位置运行应用程序时,出现异常:

org.h2.jdbc.JdbcSQLException: IO Exception: "java.io.FileNotFoundException: C:\Program Files (x86)\Aurora Game Hub\bin\AuroraDB.lock.db (Access is denied)"; "C:/Program Files (x86)/Aurora Game Hub/bin/AuroraDB.lock.db" [90031-167]
        at org.h2.message.DbException.getJdbcSQLException(DbException.java:329)
        at org.h2.message.DbException.get(DbException.java:158)
        at org.h2.message.DbException.convertIOException(DbException.java:315)
        at org.h2.store.fs.FilePathDisk.newOutputStream(FilePathDisk.java:265)
        at org.h2.store.fs.FileUtils.newOutputStream(FileUtils.java:223)
        at org.h2.store.FileLock.save(FileLock.java:197)
        at org.h2.store.FileLock.lockFile(FileLock.java:333)
        at org.h2.store.FileLock.lock(FileLock.java:128)
        at org.h2.engine.Database.open(Database.java:542)
        at org.h2.engine.Database.openDatabase(Database.java:222)
        at org.h2.engine.Database.<init>(Database.java:217)
        at org.h2.engine.Engine.openSession(Engine.java:56)
        at org.h2.engine.Engine.openSession(Engine.java:159)
        at org.h2.engine.Engine.createSessionAndValidate(Engine.java:138)
        at org.h2.engine.Engine.createSession(Engine.java:121)
        at org.h2.engine.Engine.createSession(Engine.java:28)
        at org.h2.engine.SessionRemote.connectEmbeddedOrServer(SessionRemote.java:305)
        at org.h2.jdbc.JdbcConnection.<init>(JdbcConnection.java:110)
        at org.h2.jdbc.JdbcConnection.<init>(JdbcConnection.java:94)
        at org.h2.Driver.connect(Driver.java:72)
        at java.sql.DriverManager.getConnection(Unknown Source)
        at java.sql.DriverManager.getConnection(Unknown Source)
        at aurora.engine.V1.Logic.ASimpleDB.searchAprox(ASimpleDB.java:828)
        at aurora.V1.core.GameSearch.searchGame(GameSearch.java:249)
        at aurora.V1.core.GameSearch.run(GameSearch.java:346)
        at java.lang.Thread.run(Unknown Source)
Caused by: java.io.FileNotFoundException: C:\Program Files (x86)\Aurora Game Hub\bin\AuroraDB.lock.db (Access is denied)
        at java.io.FileOutputStream.open(Native Method)
        at java.io.FileOutputStream.<init>(Unknown Source)
        at java.io.FileOutputStream.<init>(Unknown Source)
        at org.h2.store.fs.FilePathDisk.newOutputStream(FilePathDisk.java:257)
        ... 22 more

当它不在程序文件位置时它工作正常,因为我在开发时会注意到这一点。

我认为这与权限和无法创建锁定文件或其他东西有关。有没有办法给予/请求明确的权限来创建锁定文件,或者我可以告诉 H2 不要创建锁定文件吗?

我们考虑过将静态数据库放置在安装位置以外的其他位置,但由于它必须在 Mac 和 PC 上运行以及安装程序的设置方式,因此会使事情变得更加复杂。

任何帮助将不胜感激。

最佳答案

似乎没有写入此目录的访问权限。您需要将数据库文件存储在您有访问权限的目录中。

对于 H2,如果使用数据库 URL jdbc:h2:~/data/db,数据库将相对于当前用户主目录进行存储。另一种选择是使用绝对路径,例如 jdbc:h2:c:/dir/to/db/file

关于java - 在程序文件夹中创建锁定文件会导致异常,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14432460/

相关文章:

java - 如何在android中设置特定时间的日历

node.js - Node Express Unix 域套接字权限

linux - 如何从目录中删除 ACL 并恢复到通常的访问控制?

php chmod() 不改变权限

java正则表达式匹配一个字符串

java - 使用鼠标点击生成球

java - SherlockFragment 内未定义的 onKeyDown

c++ - static lock_guard 和 static mutex 也一样吗?

c# - 锁定是否确保从缓存中清除读取和写入?如果是这样,如何?

多个线程共享的 Python 内存数组(想想进程空间中的 memcached)