H2 Database multiple connections

2019-02-12 16:40发布

I have the following issue: Two instances of an application on two different systems should share a small database. The main problem is that both systems can only exchange data through a network-folder. I don't have the possibilty to setup a database-server somewhere.

Is it possible to place a H2 database on the network-folder and let both instances connect to the database (also concurrently)?

I could connect with both instances to the db using the embedded mode if I disable the file-locking, right? The instances can perfom either READ or INSERT operations on the db. Do I risk data corruptions using multiple concurrent embedded connections?

标签: h2
2条回答
Emotional °昔
2楼-- · 2019-02-12 17:25

I had the same issue and I've found the solution in the documentation. It can be found at; http://h2database.com/html/features.html#auto_mixed_mode

Multiple processes can access the same database without having to start the server manually. To do that, append ;AUTO_SERVER=TRUE to the database URL. You can use the same database URL independent of whether the database is already open or not. This feature doesn't work with in-memory databases.

// Application 1:
DriverManager.getConnection("jdbc:h2:/data/test;AUTO_SERVER=TRUE");

// Application 2:
DriverManager.getConnection("jdbc:h2:/data/test;AUTO_SERVER=TRUE");
查看更多
叼着烟拽天下
3楼-- · 2019-02-12 17:27

From H2 documentation:

It is also possible to open the database without file locking; in this case it is up to the application to protect the database files. Failing to do so will result in a corrupted database.

I think that if your application use always the same configuration (shared file database on network folder), you need to create an application layer that manages concurrency

查看更多
登录 后发表回答