首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >弹性搜索与neo4j数据库的集成

弹性搜索与neo4j数据库的集成
EN

Stack Overflow用户
提问于 2018-01-30 09:46:56
回答 2查看 1.1K关注 0票数 1

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

  1. 安装neo4j
  2. 已安装的弹性搜索
  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是如何集成的。请澄清这一点。

我跟踪了这个,

链接

EN

回答 2

Stack Overflow用户

发布于 2018-01-30 10:09:02

您必须安装Apoc过程插件(https://github.com/neo4j-contrib/neo4j-apoc-procedures)。关于ES集成的文档如下:ES与Apoc过程的集成

编辑

  • 下载并将apoc.jar放到插件的Neo4j目录中,关于目标的Neo4j版本
  • 重启Neo4j
  • 在Neo4j Web浏览器中,启动以下Cypher查询以显示所有ES过程: CALL apoc.help("apoc.es")

对日志的示例查询:

代码语言:javascript
复制
CALL apoc.es.getRaw("localhost","_search?q=level:ERROR",null) 
YIELD value 
UNWIND value.hits.hits as hits
RETURN hits LIMIT 100

重新命令的方法是通过添加一个键(重启neo4j.conf后)将ES主机存储在Neo4j中:

apoc.es.myKey.url=localhost

然后,查询如下:

代码语言:javascript
复制
CALL apoc.es.getRaw("myKey","_search?q=level:ERROR",null) 
YIELD value 
UNWIND value.hits.hits as hits
RETURN hits LIMIT 100
票数 1
EN

Stack Overflow用户

发布于 2019-11-20 23:47:37

对于已经安装和访问APOC插件但不能访问neo4j.properties文件(或者通过curl使用ES更舒服)的人,您可以不使用apoc.es.getRaw就可以这样做,而可以使用apoc.load.json返回的JSON。

代码语言:javascript
复制
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
...
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/48518360

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档