我有Jersery服务,我使用Neo4j嵌入式数据库来处理数据请求。
现在,当我发出并发的GET请求时,它可以正常工作。
但是,当我发出并发的POST请求时,它提供了以下例外:
Caused by: org.neo4j.kernel.lifecycle.LifecycleException: Component 'org.neo4j.kernel.StoreLockerLifecycleAdapter@62f1ca5e' was successfully initialized, but failed to start. Please see attached cause exception.
at org.neo4j.kernel.lifecycle.LifeSupport$LifecycleInstance.start(LifeSupport.java:504)
at org.neo4j.kernel.lifecycle.LifeSupport.start(LifeSupport.java:115)
at org.neo4j.kernel.InternalAbstractGraphDatabase.run(InternalAbstractGraphDatabase.java:296)
... 42 more
Caused by: org.neo4j.kernel.StoreLockException: Could not create lock file
at org.neo4j.kernel.StoreLocker.checkLock(StoreLocker.java:85)
at org.neo4j.kernel.StoreLockerLifecycleAdapter.start(StoreLockerLifecycleAdapter.java:40)
at org.neo4j.kernel.lifecycle.LifeSupport$LifecycleInstance.start(LifeSupport.java:498)我知道问题是,如果已经有运行neo4j的实例,我们就不能使用另一个线程访问相同的实例。
解决方案将是Neo4j HA
但是,由于我没有足够的时间配置Neo4j HA集群,是否有人可以建议我如何使POST请求为单线程(意味着没有并发线程同时访问Neo4j )。
任何链接或教程。
编辑
我是这样开始neo4j的:
GraphDatabaseService graphdb = new GraphDatabaseFactory().newEmbeddedDatabase("D:/GraphDB");'在finally区,我正在做
graphdb.shutdown();发布于 2013-11-18 12:06:12
不确定在这种情况下GET请求是如何工作的,也许Neo4j团队的某个人可以提供一个最好的解释。我假设您使用每个请求初始化和关闭graphdb。另外,我最近没有和Java联系,我的建议可能不准确。
我认为我处理这一问题的方式是不使用每个请求初始化和关闭graphdb。原因是Neo4j锁定了一个图形数据库目录,并且不允许一个新线程重新初始化同一个目录上的嵌入式实例(读取线程安全)。相反,我宁愿使用一个单例类,它公开了graphdb,并在JVM中作为共享对象重用它。graphdb.shutdown()可能发生在泽西服务的关闭钩子中(只有在服务关闭时,graphdb才会关闭)。这符合泛欧洲的建议,ServletContextListener是一个很好的地方来做这件事。然而,执行情况可能因泽西岛而异。
最后,我会礼貌地对待那些试图通过编辑你的问题、评论和询问问题背景来帮助你的人。:)
发布于 2014-06-24 06:45:58
要回答这个问题为时已晚,但如果有人面临同样的问题,我就是这样解决的。保持一个单例类。也就是说,
GraphDatabaseService graphdb=null;
if(graphdb.isAvailable()&& graphdb!=null)
{
return graphdb;
}
else
{
graphdb = new GraphDatabaseFactory().newEmbeddedDatabase("D:/GraphDB");
return graphdb;
}https://stackoverflow.com/questions/18916676
复制相似问题