将elasticsearch与neo4j数据库集成

时间:2018-01-30 09:46:57

标签: elasticsearch neo4j elasticsearch-plugin elasticsearch-5

我试图在我的neo4j数据库中使用elasticsearch进行快速查询。我尝试了很多网站,但它们都是旧文章,所以我没有得到任何明确的想法。我一直遵循的步骤,直到现在,

  1. 已安装neo4j
  2. 已安装的elasticsearch
  3. 将粘贴的弹性搜索插件复制到neo4j插件文件夹
  4. 将此行添加到neo4j中。属性文件

    elasticsearch.host_name=http://localhost:9200
    

    elasticsearch.index_spec=people:Person(first_name,last_name), places:Place(name)

    我的问题是,

  5. 如何整合elasticsearch和neo4j。请澄清一下。

  6. 我跟着这个,

      

    Link

2 个答案:

答案 0 :(得分:1)

您必须安装Apoc程序插件(https://github.com/neo4j-contrib/neo4j-apoc-procedures)。有关ES集成的文档位于:ES Integration with Apoc procedures

[编辑]

  • 下载并删除插件的Neo4j目录中的apoc.jar,关于目标Neo4j版本

  • 重启Neo4j

  • 在Neo4j Web浏览器中,启动以下Cypher查询以显示所有ES过程:

    CALL apoc.help("apoc.es")

日志的示例查询:

CALL apoc.es.getRaw("localhost","_search?q=level:ERROR",null) 
YIELD value 
UNWIND value.hits.hits as hits
RETURN hits LIMIT 100

推荐的方法是通过添加密钥(在重启Neo4j之后)将ES主机存储在neo4j.conf中:

apoc.es.myKey.url =本地主机

然后查询如下:

CALL apoc.es.getRaw("myKey","_search?q=level:ERROR",null) 
YIELD value 
UNWIND value.hits.hits as hits
RETURN hits LIMIT 100

答案 1 :(得分:0)

对于已经安装了APOC插件并且可以访问但又无法访问neo4j.properties文件(或者更愿意通过curl使用ES的用户),可以不用使用apoc.es.getRaw而是可以使用apoc.load.json返回的JSON:

WITH "http://myelasticurl:9200/my_index/_search?q=level:ERROR" as search_url
CALL apoc.load.json(search_url) YIELD value
UNWIND value.hits.hits as hit
WITH hit._source as source
...
# do work
...