
luceneappengine
PROJECT AND WIKI MOVED TO GITHUB https://github.com/UltimaPhoenix/luceneappengine
This project provides a directory useful to build Lucene and Google App Engine powered applications.
Welcome to Lucene App Engine project (aka. LAE)
Main Features: * LAE 3.0.x compatible with Lucene 5.0.x * LAE 2.2.x compatible with Lucene 4.10.x, 4.9.x (needs Java 7, I will not say it anymore) * LAE 2.1.x compatible with Lucene 4.9.x (needs Java 7) * LAE 2.0.x compatible with Lucene 4.8.x (needs Java 7) * LAE 1.2.x compatible with Lucene 4.7.x * LAE 1.1.x compatible with Lucene 4.6.x * LAE 1.0.x compatible with Lucene 4.0.x, 4.1.x, 4.2.x, 4.3.x, 4.4.x, 4.5.x * Objecitfy updated to 5.1.x * Storage in Google App Engine * Supported operations: Add, Remove, Update, Index, Deindex, everything?! (I need you to check) * Multiple indexes in the same application * No more (the wrong) RAMDirectory for Google App Engine powered applications * No more index size limit of 1MB * Yes! It works, see it in action (live demo site) * Open your mind to new Google App Engine applications powered by Lucene * For high performance applications use google app engine task queue * Memcache supported and integrated for all versions * Distributed on maven central * Easier to configure than the previous LAE version
Coming Soon: * Performance improvements: * asynch indexing * buffer management
News
- 05-07-2015 Wiki officially moved to GitHub (Updates on this page will be discontinued)
- 05-07-2015 Released New LAE-3.0.0 compatible with Lucene 5.0.0 (this is a major release with breaking changes)
- 17-09-2014 Released New LAE-2.2.0 compatible with Lucene 4.10.x and Lucene 4.9.x (needs Java 7)
- 10-08-2014 Released New LAE-2.1.0 compatible with Lucene 4.9.x (needs Java 7)
- 23-07-2014 Released New LAE-2.0.1 bugfix and performance improvements release, all other versions are now deprecated
- 20-05-2014 Released New LAE-2.0.0 compatible with Lucene 4.8.x (needs Java 7)
- 05-04-2014 Released New LAE-1.2.0 compatible with Lucene 4.7.x
- 05-04-2014 Released New LAE-1.1.0 compatible only with Lucene 4.6.x
- 03-04-2014 Migration of source code completed on GitHub
- 03-04-2014 Released New LAE-1.0.3 on Maven central
- 03-04-2014 Discontinued Objecfity 3 support, if you need it refer to the old site
- 03-04-2014 Discontinued Lucene 3.6.x support, if you need it refer to the old site
Usage
GaeDirectory directory = new GaeDirectory();//create a default index
IndexWriterConfig config = GaeLuceneUtil.getIndexWriterConfig(analyzer);//get configuration if you are using a LAE version less than 3.x.x add LUCENE_VERSION as parameter
IndexWriter w = new IndexWriter(directory, config);//get the writer
/* now use Apache Lucene like you're used to */
In order to manage multiple index instances simply create multiple GaeDirectory instances with different names:
GaeDirectory directory = new GaeDirectory("anotherIndexName");
A complete example with source code lucene-appengine-examples
Configuration
Add into your WEB-INF/web.xml the objectify servlet (see objectify documenation for details and alternatives):
<web-app …>
…
<filter>
<filter-name>ObjectifyFilter</filter-name>
<filter-class>com.googlecode.objectify.ObjectifyFilter</filter-class>
</filter>
<filter-mapping>
<filter-name>ObjectifyFilter</filter-name>
<url-pattern>*</url-pattern>
</filter-mapping>
…
</web-app>
Add into your WEB-INF/appengine-web.xml:
<appengine-web-app>
....
<class-loader-config>
<priority-specifier filename="luceneappengine-[LAE Version].jar"/>
</class-loader-config>
.....
<system-properties>
...
<property name="os.version" value="1.0.GAE whatever" />
<property name="os.arch" value="GAE whatever" />
</system-properties>
</appengine-web-app>
WARNING: If you are using a SNAPSHOT version of LAE using Maven, you must add the specific jar name of the snapshot, you can see the specific jar name typing on command line 'mvn clean package && ls -lR target/ | grep lucene-appengine'
Maven
If you are using maven to build/deploy google app engine war add this snippet to import the lucene directory
<dependencies>
<!-- Declare dependencies in this order -->
<dependency>
<groupId>com.googlecode.luceneappengine</groupId>
<artifactId>luceneappengine</artifactId>
<version>3.0.0</version>
</dependency>
<dependency>
<groupId>org.apache.lucene</groupId>
<artifactId>lucene-core</artifactId>
<version>5.0.0</version>
</dependency>
<dependency>
<groupId>org.apache.lucene</groupId>
<artifactId>lucene-analyzers-common</artifactId>
<version>5.0.0</version>
</dependency>
....
</dependencies>
For a complete example and source-code see LAE Examples project
Development
If you like this project, you can choose a kind of donation here or give a free donation
. Thanks for your support!