私はJetty 9.2で動作するJavaアプリケーションを持っています。どちらも同じバージョンのJettyを使用します。インデクサは、デプロイ後にアプリケーションが最初に起動するときに実行されます。私は、NetbeansのWindowsデベロッパーボックスに何か問題がありました。それは私がSSHアクセスと制限付きの権利しか持っていないLinuxマシンに置いたときには動作しません。LuceneのインデクサーはWindowsで動作し、Linuxでは失敗します
java code、クラスPersonが最初に実行され、クラスOrganizationがsecondを実行します。両者が同じでセッション
public static void reindexViaMassIndexer(Class<?> type, SessionFactory factory) {
Session session = factory.getCurrentSession();
FullTextSession fullTextSession = Search.getFullTextSession(session);
MassIndexerProgressMonitor monitor = new SimpleIndexingProgressMonitor();
try {
fullTextSession
.createIndexer(type)
.typesToIndexInParallel(1)
.batchSizeToLoadObjects(BATCH_SIZE)
.cacheMode(CacheMode.NORMAL)
.threadsToLoadObjects(10)
.idFetchSize(BATCH_SIZE)
.progressMonitor(monitor)
.startAndWait();
} catch (InterruptedException ex) {
Logger.getLogger(HibernateLuceneIndexer.class.getName()).log(Level.SEVERE, null, ex);
}
}
ポンポンが
<dependency>
<groupId>org.hibernate</groupId>
<artifactId>hibernate-search-orm</artifactId>
<version>5.2.0.Final</version>
</dependency>
<dependency>
<groupId>org.hibernate</groupId>
<artifactId>hibernate-c3p0</artifactId>
<version>4.3.9.Final</version>
</dependency>
エラー出力
17:48:00,188 ERROR LogErrorHandler:67 - HSEARCH000058: Exception occurred org.apache.lucene.store.LockObtainFailedException: Lock obtain timed out: [email protected]/tmp/cyberdex_files/org.vtarc.CyberConnections.backend.entity.Organization/write.lock: java.nio.channels.OverlappingFileLockException
Primary Failure:
Entity org.vtarc.CyberConnections.backend.entity.Organization Id null Work Type org.hibernate.search.backend.PurgeAllLuceneWork
org.apache.lucene.store.LockObtainFailedException: Lock obtain timed out: [email protected]/tmp/cyberdex_files/org.vtarc.CyberConnections.backend.entity.Organization/write.lock: java.nio.channels.OverlappingFileLockException
at org.apache.lucene.store.Lock.obtain(Lock.java:89)
at org.apache.lucene.index.IndexWriter.<init>(IndexWriter.java:755)
at org.hibernate.search.backend.impl.lucene.IndexWriterHolder.createNewIndexWriter(IndexWriterHolder.java:131)
at org.hibernate.search.backend.impl.lucene.IndexWriterHolder.getIndexWriter(IndexWriterHolder.java:97)
at org.hibernate.search.backend.impl.lucene.AbstractWorkspaceImpl.getIndexWriter(AbstractWorkspaceImpl.java:112)
at org.hibernate.search.backend.impl.lucene.LuceneBackendQueueTask.applyUpdates(LuceneBackendQueueTask.java:81)
at org.hibernate.search.backend.impl.lucene.LuceneBackendQueueTask.run(LuceneBackendQueueTask.java:47)
at org.hibernate.search.backend.impl.lucene.SyncWorkProcessor$Consumer.applyChangesets(SyncWorkProcessor.java:145)
at org.hibernate.search.backend.impl.lucene.SyncWorkProcessor$Consumer.run(SyncWorkProcessor.java:135)
at java.lang.Thread.run(Thread.java:745)
Caused by: java.nio.channels.OverlappingFileLockException
at sun.nio.ch.SharedFileLockTable.checkList(FileLockTable.java:255)
at sun.nio.ch.SharedFileLockTable.add(FileLockTable.java:152)
at sun.nio.ch.FileChannelImpl.tryLock(FileChannelImpl.java:1108)
at java.nio.channels.FileChannel.tryLock(FileChannel.java:1155)
at org.apache.lucene.store.NativeFSLock.obtain(NativeFSLockFactory.java:169)
at org.apache.lucene.store.Lock.obtain(Lock.java:96)
... 9 more
者指数成功したファイルを休止状態、組織が失敗しました。注意:親ディレクトリはjetty:jetty(user:group)です。
[[email protected] org.vtarc.CyberConnections.backend.entity.Person]$ ls -l
-rw-r-----. 1 jetty jetty 1844 Oct 20 18:43 _9.fdt
-rw-r-----. 1 jetty jetty 67 Oct 20 18:43 _9.fdx
-rw-r-----. 1 jetty jetty 1310 Oct 20 18:43 _9.fnm
-rw-r-----. 1 jetty jetty 3687 Oct 20 18:43 _9_Lucene41_0.doc
-rw-r-----. 1 jetty jetty 4310 Oct 20 18:43 _9_Lucene41_0.pos
-rw-r-----. 1 jetty jetty 20500 Oct 20 18:43 _9_Lucene41_0.tim
-rw-r-----. 1 jetty jetty 576 Oct 20 18:43 _9_Lucene41_0.tip
-rw-r-----. 1 jetty jetty 1530 Oct 20 18:43 _9.nvd
-rw-r-----. 1 jetty jetty 171 Oct 20 18:43 _9.nvm
-rw-r-----. 1 jetty jetty 386 Oct 20 18:43 _9.si
-rw-r-----. 1 jetty jetty 102 Oct 20 18:43 segments_a
-rw-r-----. 1 jetty jetty 36 Oct 20 18:43 segments.gen
-rw-r-----. 1 jetty jetty 0 Oct 20 14:31 write.lock
[[email protected] org.vtarc.CyberConnections.backend.entity.Person]$ cd ../org.vtarc.CyberConnections.backend.entity.Organization/
[[email protected] org.vtarc.CyberConnections.backend.entity.Organization]$ ls -l
-rw-r-----. 1 jetty jetty 53 Oct 20 15:40 segments_5
-rw-r-----. 1 jetty jetty 36 Oct 20 15:40 segments.gen
-rw-r-----. 1 jetty jetty 0 Oct 20 14:31 write.lock
は他に何か必要ですか?
私は2つの場所でHibernateセッションをスピンアップしますが、最初はサーブレットが初期化され、インデクサーが終了した後に閉じられますが、これは解決されたいくつかのバグがあります。 2番目のセッションは、メインUIが後で初期化されるまで開始されません。これは範囲内にとどまります。 – AFowler
オプション番号2または競合状態のいずれかのようです。私は情報をデバッグに変更し、すべてが機能しました。そのため、ログが増えるとアプリの動作が少し遅くなり、すべてが正常に実行されます。この理論が正しいかどうかを確認する別のテストを待っています。 – AFowler
@AFowler私はSession * Factory *について話していたことに注意してください。並列で複数のセッションを使用するとうまくいくはずですが、同じインデックスを使用しているいくつかのSessionFactoryでは動作しません。すでに述べたように、これはHibernate Searchの古いバージョンであり、バグかもしれないので、 "*はうまく動作するはずです"と言う。 –