Class ElasticsearchIndex
- java.lang.Object
- 
- org.eclipse.rdf4j.sail.lucene.AbstractSearchIndex
- 
- org.eclipse.rdf4j.sail.elasticsearch.ElasticsearchIndex
 
 
- 
- All Implemented Interfaces:
- SearchIndex
 
 public class ElasticsearchIndex extends AbstractSearchIndex Requires an Elasticsearch cluster with the DeleteByQuery plugin.- See Also:
- LuceneSail
 
- 
- 
Field SummaryFields Modifier and Type Field Description static StringALL_PROPERTY_FIELDSstatic StringDEFAULT_ANALYZERstatic StringDEFAULT_DOCUMENT_TYPEstatic StringDEFAULT_INDEX_NAMEstatic StringDEFAULT_TRANSPORTstatic StringDOCUMENT_TYPE_KEYSet the parameter "documentType=" to specify the document type to use.static StringELASTICSEARCH_KEY_PREFIXstatic StringGEOPOINT_FIELD_PREFIXstatic StringGEOSHAPE_FIELD_PREFIXstatic StringINDEX_NAME_KEYSet the parameter "indexName=" to specify the index to use.static StringPROPERTY_FIELD_PREFIXstatic StringTRANSPORT_KEYSet the parameter "transport=" to specify the address of the cluster to use (e.g.static StringWAIT_FOR_ACTIVE_SHARDS_KEYSet the parameter "waitForActiveShards=" to configure ifinitializationshould wait until the specified number of shards to be active.static StringWAIT_FOR_NO_RELOCATING_SHARDS_KEYSet the parameter "waitForNoRelocatingShards=true|false" to configure ifinitializationshould wait until the are no relocating shards.static StringWAIT_FOR_NODES_KEYSet the parameter "waitForNodes=" to configure ifinitializationshould wait until the specified number of nodes are available.static StringWAIT_FOR_RELOCATING_SHARDS_KEYDeprecated.useWAIT_FOR_NO_RELOCATING_SHARDS_KEYin elastic search >= 5.xstatic StringWAIT_FOR_STATUS_KEYSet the parameter "waitForStatus=" to configure ifinitializationshould wait for a particular health status.- 
Fields inherited from class org.eclipse.rdf4j.sail.lucene.AbstractSearchIndexmaxDocs, wktFields
 
- 
 - 
Constructor SummaryConstructors Constructor Description ElasticsearchIndex()
 - 
Method SummaryAll Methods Static Methods Instance Methods Concrete Methods Modifier and Type Method Description protected voidaddDocument(SearchDocument doc)voidbegin()Begins a transaction.voidclear()Clears the indexes.voidclearContexts(Resource... contexts)This should be called from within a begin-commit-rollback block.voidcommit()Commits any changes done to the LuceneIndex since the last commit.The semantics is synchronous to SailConnection.commit(), i.e.protected SearchDocumentcopyDocument(SearchDocument doc)protected com.google.common.base.Function<? super String,? extends org.locationtech.spatial4j.context.SpatialContext>createSpatialContextMapper(Map<String,String> parameters)protected voiddeleteDocument(SearchDocument doc)protected Iterable<? extends DocumentDistance>geoQuery(IRI geoProperty, org.locationtech.spatial4j.shape.Point p, IRI units, double distance, String distanceVar, Var contextVar)protected Iterable<? extends DocumentResult>geoRelationQuery(String relation, IRI geoProperty, String wkt, Var contextVar)StringgetClusterName()protected SearchDocumentgetDocument(String id)Returns a Document representing the specified document ID (combination of resource and context), or null when no such Document exists yet.SearchDocumentgetDocument(Resource subject, Resource context)Returns a Document representing the specified Resource and Context combination, or null when no such Document exists yet.protected Iterable<? extends SearchDocument>getDocuments(String resourceId)Iterable<? extends SearchDocument>getDocuments(Resource subject)Returns a list of Documents representing the specified Resource (empty when no such Document exists yet).Each document represent a set of statements with the specified Resource as a subject, which are stored in a specific contextStringgetIndexName()Map<String,Object>getMappings()static Set<String>getPropertyFields(Set<String> fields)Filters the given list of fields, retaining all property fields.protected org.locationtech.spatial4j.context.SpatialContextgetSpatialContext(String property)String[]getTypes()voidinitialize(Properties parameters)protected BulkUpdaternewBulkUpdate()protected SearchDocumentnewDocument(String id, String resourceId, String context)protected Iterable<? extends DocumentScore>query(Resource subject, QuerySpec spec)Parse the passed query.voidrollback()org.elasticsearch.search.SearchHitssearch(Resource resource, org.elasticsearch.action.search.SearchRequestBuilder request, org.elasticsearch.index.query.QueryBuilder query)Evaluates the given query only for the given resource.org.elasticsearch.search.SearchHitssearch(org.elasticsearch.action.search.SearchRequestBuilder request, org.elasticsearch.index.query.QueryBuilder query)Evaluates the given query and returns the results as a TopDocs instance.voidshutDown()protected voidupdateDocument(SearchDocument doc)- 
Methods inherited from class org.eclipse.rdf4j.sail.lucene.AbstractSearchIndexaccept, addDocuments, addRemoveStatements, addStatement, evaluate, getIndexedTypeMapping, getResource, isGeoField, isIndexedTypeStatement, isTypeFilteringEnabled, isTypeStatement, parseLuceneQueryShape, parseQueryPoint, parseQueryShape, removeStatement
 
- 
 
- 
- 
- 
Field Detail- 
INDEX_NAME_KEYpublic static final String INDEX_NAME_KEY Set the parameter "indexName=" to specify the index to use.- See Also:
- Constant Field Values
 
 - 
DOCUMENT_TYPE_KEYpublic static final String DOCUMENT_TYPE_KEY Set the parameter "documentType=" to specify the document type to use. By default, the document type is "resource".- See Also:
- Constant Field Values
 
 - 
TRANSPORT_KEYpublic static final String TRANSPORT_KEY Set the parameter "transport=" to specify the address of the cluster to use (e.g. localhost:9300).- See Also:
- Constant Field Values
 
 - 
WAIT_FOR_STATUS_KEYpublic static final String WAIT_FOR_STATUS_KEY Set the parameter "waitForStatus=" to configure ifinitializationshould wait for a particular health status. The value can be one of "green" or "yellow". Does not wait by default.- See Also:
- Constant Field Values
 
 - 
WAIT_FOR_NODES_KEYpublic static final String WAIT_FOR_NODES_KEY Set the parameter "waitForNodes=" to configure ifinitializationshould wait until the specified number of nodes are available. Does not wait by default.- See Also:
- Constant Field Values
 
 - 
WAIT_FOR_ACTIVE_SHARDS_KEYpublic static final String WAIT_FOR_ACTIVE_SHARDS_KEY Set the parameter "waitForActiveShards=" to configure ifinitializationshould wait until the specified number of shards to be active. Does not wait by default.- See Also:
- Constant Field Values
 
 - 
WAIT_FOR_RELOCATING_SHARDS_KEY@Deprecated public static final String WAIT_FOR_RELOCATING_SHARDS_KEY Deprecated.useWAIT_FOR_NO_RELOCATING_SHARDS_KEYin elastic search >= 5.xSet the parameter "waitForRelocatingShards=" to configure ifinitializationshould wait until the specified number of nodes are relocating. Does not wait by default.- See Also:
- Constant Field Values
 
 - 
WAIT_FOR_NO_RELOCATING_SHARDS_KEYpublic static final String WAIT_FOR_NO_RELOCATING_SHARDS_KEY Set the parameter "waitForNoRelocatingShards=true|false" to configure ifinitializationshould wait until the are no relocating shards. Defaults to false, meaning the operation does not wait on there being no more relocating shards. Set to true to wait until the number of relocating shards in the cluster is 0.- See Also:
- Constant Field Values
 
 - 
DEFAULT_INDEX_NAMEpublic static final String DEFAULT_INDEX_NAME - See Also:
- Constant Field Values
 
 - 
DEFAULT_DOCUMENT_TYPEpublic static final String DEFAULT_DOCUMENT_TYPE - See Also:
- Constant Field Values
 
 - 
DEFAULT_TRANSPORTpublic static final String DEFAULT_TRANSPORT - See Also:
- Constant Field Values
 
 - 
DEFAULT_ANALYZERpublic static final String DEFAULT_ANALYZER - See Also:
- Constant Field Values
 
 - 
ELASTICSEARCH_KEY_PREFIXpublic static final String ELASTICSEARCH_KEY_PREFIX - See Also:
- Constant Field Values
 
 - 
PROPERTY_FIELD_PREFIXpublic static final String PROPERTY_FIELD_PREFIX - See Also:
- Constant Field Values
 
 - 
ALL_PROPERTY_FIELDSpublic static final String ALL_PROPERTY_FIELDS - See Also:
- Constant Field Values
 
 - 
GEOPOINT_FIELD_PREFIXpublic static final String GEOPOINT_FIELD_PREFIX - See Also:
- Constant Field Values
 
 - 
GEOSHAPE_FIELD_PREFIXpublic static final String GEOSHAPE_FIELD_PREFIX - See Also:
- Constant Field Values
 
 
- 
 - 
Method Detail- 
getClusterNamepublic String getClusterName() 
 - 
getIndexNamepublic String getIndexName() 
 - 
getTypespublic String[] getTypes() 
 - 
initializepublic void initialize(Properties parameters) throws Exception - Specified by:
- initializein interface- SearchIndex
- Overrides:
- initializein class- AbstractSearchIndex
- Throws:
- Exception
 
 - 
createSpatialContextMapperprotected com.google.common.base.Function<? super String,? extends org.locationtech.spatial4j.context.SpatialContext> createSpatialContextMapper(Map<String,String> parameters) 
 - 
getMappingspublic Map<String,Object> getMappings() throws IOException - Throws:
- IOException
 
 - 
getSpatialContextprotected org.locationtech.spatial4j.context.SpatialContext getSpatialContext(String property) - Specified by:
- getSpatialContextin class- AbstractSearchIndex
 
 - 
shutDownpublic void shutDown() throws IOException- Throws:
- IOException
 
 - 
getDocumentprotected SearchDocument getDocument(String id) throws IOException Returns a Document representing the specified document ID (combination of resource and context), or null when no such Document exists yet.- Specified by:
- getDocumentin class- AbstractSearchIndex
- Throws:
- IOException
 
 - 
getDocumentsprotected Iterable<? extends SearchDocument> getDocuments(String resourceId) throws IOException - Specified by:
- getDocumentsin class- AbstractSearchIndex
- Throws:
- IOException
 
 - 
newDocumentprotected SearchDocument newDocument(String id, String resourceId, String context) - Specified by:
- newDocumentin class- AbstractSearchIndex
 
 - 
copyDocumentprotected SearchDocument copyDocument(SearchDocument doc) - Specified by:
- copyDocumentin class- AbstractSearchIndex
 
 - 
addDocumentprotected void addDocument(SearchDocument doc) throws IOException - Specified by:
- addDocumentin class- AbstractSearchIndex
- Throws:
- IOException
 
 - 
updateDocumentprotected void updateDocument(SearchDocument doc) throws IOException - Specified by:
- updateDocumentin class- AbstractSearchIndex
- Throws:
- IOException
 
 - 
deleteDocumentprotected void deleteDocument(SearchDocument doc) throws IOException - Specified by:
- deleteDocumentin class- AbstractSearchIndex
- Throws:
- IOException
 
 - 
newBulkUpdateprotected BulkUpdater newBulkUpdate() - Specified by:
- newBulkUpdatein class- AbstractSearchIndex
 
 - 
getDocumentpublic SearchDocument getDocument(Resource subject, Resource context) throws IOException Returns a Document representing the specified Resource and Context combination, or null when no such Document exists yet.- Parameters:
- subject-
- context-
- Returns:
- search document
- Throws:
- IOException
 
 - 
getDocumentspublic Iterable<? extends SearchDocument> getDocuments(Resource subject) throws IOException Returns a list of Documents representing the specified Resource (empty when no such Document exists yet).Each document represent a set of statements with the specified Resource as a subject, which are stored in a specific context- Parameters:
- subject-
- Returns:
- list of documents
- Throws:
- IOException
 
 - 
getPropertyFieldspublic static Set<String> getPropertyFields(Set<String> fields) Filters the given list of fields, retaining all property fields.- Parameters:
- fields-
- Returns:
- set of fields
 
 - 
beginpublic void begin() throws IOExceptionDescription copied from interface:SearchIndexBegins a transaction.- Throws:
- IOException
 
 - 
commitpublic void commit() throws IOExceptionDescription copied from interface:SearchIndexCommits any changes done to the LuceneIndex since the last commit.The semantics is synchronous to SailConnection.commit(), i.e. the LuceneIndex should be committed/rolled back whenever the LuceneSailConnection is committed/rolled back.- Throws:
- IOException
 
 - 
rollbackpublic void rollback() throws IOException- Throws:
- IOException
 
 - 
queryprotected Iterable<? extends DocumentScore> query(Resource subject, QuerySpec spec) throws MalformedQueryException, IOException Parse the passed query.- Specified by:
- queryin class- AbstractSearchIndex
- Parameters:
- subject-
- spec- query to process
- Returns:
- the parsed query
- Throws:
- MalformedQueryException
- IOException
- IllegalArgumentException- if the spec contains a multi-param query
 
 - 
searchpublic org.elasticsearch.search.SearchHits search(Resource resource, org.elasticsearch.action.search.SearchRequestBuilder request, org.elasticsearch.index.query.QueryBuilder query) Evaluates the given query only for the given resource.- Parameters:
- resource-
- request-
- query-
- Returns:
- search hits
 
 - 
geoQueryprotected Iterable<? extends DocumentDistance> geoQuery(IRI geoProperty, org.locationtech.spatial4j.shape.Point p, IRI units, double distance, String distanceVar, Var contextVar) throws MalformedQueryException, IOException - Specified by:
- geoQueryin class- AbstractSearchIndex
- Throws:
- MalformedQueryException
- IOException
 
 - 
geoRelationQueryprotected Iterable<? extends DocumentResult> geoRelationQuery(String relation, IRI geoProperty, String wkt, Var contextVar) throws MalformedQueryException, IOException - Specified by:
- geoRelationQueryin class- AbstractSearchIndex
- Throws:
- MalformedQueryException
- IOException
 
 - 
searchpublic org.elasticsearch.search.SearchHits search(org.elasticsearch.action.search.SearchRequestBuilder request, org.elasticsearch.index.query.QueryBuilder query)Evaluates the given query and returns the results as a TopDocs instance.
 - 
clearContextspublic void clearContexts(Resource... contexts) throws IOException Description copied from interface:SearchIndexThis should be called from within a begin-commit-rollback block.- Parameters:
- contexts-
- Throws:
- IOException
 
 - 
clearpublic void clear() throws IOExceptionDescription copied from interface:SearchIndexClears the indexes.- Throws:
- IOException
 
 
- 
 
-