On 01/05/2020 21:08, Bart van Leeuwen wrote:
Hi,

I'm trying to migrate a web application which uses TDB to use TDB2

From everything I have ready it should be pretty straight forward, but I immediately run into exceptions like:

java.nio.channels.OverlappingFileLockException

I don't know what this is - it may be an environment factor. Is this Docker? Virtual machines?

Or are there classloaders around?


org.apache.jena.tdb2.TDBException: dataset closed

In TDB1 close() does not have any effect except that it flushes the database if the dataset has never been used transactionally.

There is no need to close databases - transactions are better/safer/robust. In fact, it is a bit meaningless with transactions because there are different views of the data fro different threads.

org.apache.jena.dboe.transaction.txn.TransactionException: Currently in an active transaction

This is API use of the dataset (not Fuseki)?

TDB1 works non-transactionally until the app first uses it in a transaction.

TDB2 requires transactions from the start.

Ideally, use Txn to wrap dataset access. Txn both supports nesting of usage (it is not nested tranactions - it uses the existing trasnaction) and the patten means the code can't forget to commit/abort.

https://jena.apache.org/documentation/txn/
https://jena.apache.org/documentation/txn/txn.html

Sometimes, apps have code usage that doesn't fit this pattern.

---

It looks like there is non-transactional use of the dataset at some point.

This does not obviously explain java.nio.channels.OverlappingFileLockException
but it might be related.

    Andy


I've looked at the samples and the minimal tutorials I could find and couldn't find hints  on what could cause this.

I did a initdebug:

Looks OK.


JenaSystem.init - start
Found:
   InitTDB2       [42]
   InitRIOT       [20]
   InitARQ        [30]
   InitJenaCore   [10]
Initialization sequence:
   JenaInitLevel0   [0]
   InitJenaCore   [10]
   InitRIOT       [20]
   InitARQ        [30]
   InitTDB2       [42]
Init: JenaInitLevel0
Init: InitJenaCore
JenaCore.init - start
JenaCore.init - finish
Init: InitRIOT
RIOT.init - start
RIOT.init - finish
Init: InitARQ
ARQ.init - start
ARQ.init - finish
Init: InitTDB2
TDB2.init - start
TDB.init - finish
JenaSystem.init - finish

Any help appreciated.

Met Vriendelijke Groet / With Kind Regards
Bart van Leeuwen


twitter: @semanticfire
tel. +31(0)6-53182997
Netage B.V.
http://netage.nl <http://netage.nl/>
Esdoornstraat 3
3461ER Linschoten
The Netherlands

Reply via email to