A new highly flexible, highly scalable document ingestion system.
See the web site and the documentation for more info
Please see the documentation in the wiki
Current release version: 1.0-beta2.
Can be used with gradle configuration:
repositories {
mavenCentral()
maven {
url 'https://jesterj.jfrog.io/jesterj/libs-release/'
}
maven {
url 'https://clojars.org/repo'
}
}
dependencies {
compile ('org.jesterj:ingest:1.0-beta2')
}
The extra repos are for a patched version of cassandra, and should go away in future releases (see https://issues.apache.org/jira/browse/CASSANDRA-13396). The clojars repo is for is for a clojure based implementation of docopt, which will hopefully become unnecessary in future versions.
Presently only JDK 8 has been supported. JDK 9/10 will not be explicitly supported. Now that JDK 11 is out as an LTS version, support for it will commence.
If you want an invite to our slack channel just send mail to:
______ _ __ _
____ ___ _______/ ____ \ (_)__ _____/ /____ _____(_)____ _________ _
/ __ `/ / / / ___/ / __ `/ / / _ \/ ___/ __/ _ \/ ___/ // __ \/ ___/ __ `/
/ /_/ / /_/ (__ ) / /_/ / / / __(__ ) /_/ __/ / / // /_/ / / / /_/ /
\__, /\__,_/____/\ \__,_/_/ /\___/____/\__/\___/_/__/ (_)____/_/ \__, /
/____/ \____/___/ /___/ /____/
In this release we have the following features
- Embedded Cassandra server
- Cassandra config and data location configurable, defaults to ~/.jj/cassandra
- Initial support for fault tolerance via logging statuses to the embedded cassandra server (WIP)
- Log4j appender to write to Cassandra where desired
- Initial API/process for user written steps. (see documentation)
- 40% test coverage (jacoco)
- Simple filesystem scanner
- Copy Field processor
- Date Reformat processor
- Human Readable File Size processor
- Tika processor to extract content
- Solr sender to send documents to solr in batches.
- Runnable example to execute a plan that scans a filesystem, and indexes the documents in solr.
Release 0.1 is intended to be the smallest functional unit. Plans and steps will need to be assembled in code etc and only run locally, only single node supported. Documents indexed will have fields for mod-time, file name and file size.
- JDBC scanner
- Cassandra based FTI
- Document hashing to detect changed docs (any scanner)
- Node and Transport style senders for Elastic
- Ability to load Java based config from a jar file - experimental.
- More processors: Fetch URL, Regex Replace Value, Delete Field, Parse Field as Template, URL Encode Field
- Publish jars on Maven Central
- Up to date docs in wiki.
The Java config feature is experimental but working out better than expected. I wanted to use what I had built for a project, but the lack of externalized configuration was a blocker. It was a quick fix but it's turning out to be quite pleasant to work with. The down side is I'm not sure how it would carry forward to later stages of the project so it might still go away. Feedback welcome.
- 50% test coverage
- fix nsoft#84
- Build a demo jar that can be run to demonstrate the java config usage
- Demo/tutorial to demonstrate indexing a database and a filesystem simultaneously into solr
Release 1.0 is intended to be the usable for single node systems, and therefore suitable for production use on small to medium sized projects.
- Serialized format for a plan/steps.
- JINI Registrar
- Register Node Service on JINI Registrar
- Display nodes visible in control web app.
- JINI Service to accept serialized format
- Ability to build a plan in web-app.
- 60% test coverage
- Availability on maven central.
- Build and run the 0.2 scenario via the control web-app.
Release 2.0 is intended to be similar to 1.0 but with a very basic web control UI. At this point it should be possible to install the war file, start a node,
- secure connections among nodes and with the web app. (credential provider)
- Ensure nodes namespace their cassandra data dirs to avoid disasters if more than one node run per user account
- Cassandra cluster formation
- pass Documents among nodes using Java Spaces
- Support for adding helper nodes that scale a step or several steps horizontally.
- Make the control UI pretty.
Release 3.0 is intended to be the first release to spread work across nodes.
FTI stands for Fault Tolerant Indexing. For our purposes this means that once a scanner is pointed at a document source, it is guaranteed to eventually do one of the following things with every qualifying document:
- Process the document and send it to solr.
- Log an error explaining why the document processing failed.
It will do this no matter how many nodes fail, or how many times Solr is rebooted