Docker 容器内运行的 Neo4j 实例 安装apoc插件

插件

本页描述了如何将插件安装到在 Docker 容器内运行的 Neo4j 实例中。有关插件的一般说明,请参见配置 → 插件。

安装插件

安装插件,包括用户定义的程序,将包含插件 JAR 的文件夹或卷挂载到 /plugins ,例如:

highlight 复制代码
docker run \
   --publish=7474:7474 --publish=7687:7687 \
   --volume=$HOME/neo4j/plugins:/plugins \
   neo4j:5.20.0

Neo4j 自动加载在启动时在 /plugins 文件夹中找到的任何插件。

NEO4J_PLUGINS 实用程序

Neo4j Docker 映像包括一个启动脚本,可以在运行时自动下载和配置特定的 Neo4j 插件。

|-------------------------------------------------------------------------------------|
| 此功能旨在简化在开发环境中使用 Neo4j 插件的过程,但不建议在生产环境中使用。 要在生产中使用 Neo4j Docker 容器中的插件,请参阅安装用户定义的过程。 |

NEO4J_PLUGINS 环境变量可用于指定使用此方法安装的插件。应将其设置为支持插件的 JSON 格式列表。

|---------------------------------------------------------|
| 在 Docker 容器中运行 Bloom 需要 Neo4j Docker 镜像 4.2.3 企业版或更高版本。 |

如果传递了无效的 NEO4J_PLUGINS 值,Neo4j 将返回一个通知,指出插件未知。例如, --env NEO4J_PLUGINS='["gds"]' 将返回以下通知:
示例输出

highlight 复制代码
"gds" is not a known Neo4j plugin. Options are:
apoc
apoc-extended
bloom
graph-data-science
graphql
n10s

示例 1. 安装 APOC 核心插件 ( apoc )
您可以使用 Docker 参数 --env NEO4J_PLUGINS='["apoc"]' 并运行以下命令:

highlight 复制代码
docker run -it --rm \
  --publish=7474:7474 --publish=7687:7687 \
  --env NEO4J_AUTH=none \
  --env NEO4J_PLUGINS='["apoc"]' \
  neo4j:5.20.0

示例 2. 安装 APOC 核心插件 ( apoc ) 和图形数据科学插件 ( graph-data-science )
您可以使用 Docker 参数 --env NEO4J_PLUGINS='["apoc", "graph-data-science"]' 并运行以下命令:

highlight 复制代码
docker run -it --rm \
  --publish=7474:7474 --publish=7687:7687 \
  --env NEO4J_AUTH=none \
  --env NEO4J_PLUGINS='["apoc", "graph-data-science"]' \
  neo4j:5.20.0

存储下载的插件

在带宽受限的情况下,或者 Neo4j 经常停止和启动的情况下,可能希望只下载插件一次并重复使用,而不是每次都下载插件。
通过使用 NEO4J_PLUGINS 实用程序与对 /plugins 进行存储挂载的结合,插件 jar 文件将被下载到 /plugins 文件夹中。然后可以在以后再次使用它,以向 Neo4j 提供相同的插件,而无需设置 NEO4J_PLUGINS
示例 3。使用 Docker 自动下载和重复使用插件的示例。
获取 APOC 插件并将其保存到 $HOME/neo4j/plugins

highlight 复制代码
docker run -it --rm \
  --publish=7474:7474 --publish=7687:7687 \
  --env NEO4J_AUTH=none \
  --env NEO4J_PLUGINS='["apoc"]' \
   --volume=$HOME/neo4j/plugins:/plugins \
  neo4j:5.20.0

|---|----------------------------------------------|
| | 挂载主机文件夹 $HOME/neo4j/plugins/plugins 。 |

验证 apoc 插件已下载。

highlight 复制代码
docker kill <containerID/name>
ls $HOME/neo4j/plugins
  apoc.jar

开始一个新容器并验证 apoc 是否已安装。

highlight 复制代码
docker run -it --rm \
  --publish=7474:7474 --publish=7687:7687 \
  --env NEO4J_AUTH=none \
   --volume=$HOME/neo4j/plugins:/plugins \
  neo4j:5.20.0

cypher-shell "RETURN apoc.version();"

安装插件许可证

如果插件需要许可证,许可证文件可以通过将包含许可证文件的文件夹或卷挂载到 /licenses 来提供给容器。

|-------------------------|
| 要检查插件是否需要许可证,请参考通用插件文档。 |

示例 4. 通过挂载文件夹到容器来安装插件和许可证

highlight 复制代码
docker run \
   --publish=7474:7474 --publish=7687:7687 \
   --volume=$HOME/neo4j/plugins:/plugins \
   --volume=$HOME/neo4j/licenses:/licenses \
   neo4j:5.20.0

|---|------------------|
| | 包含插件 jar 文件的文件夹。 |
| | 包含许可文件的文件夹。 |

必须提供许可证,如果使用 NEO4J_PLUGINS 实用程序来安装插件。
示例 5。使用 NEO4J_PLUGINS 工具将文件夹挂载到容器以安装插件和许可证

highlight 复制代码
docker run \
   --publish=7474:7474 --publish=7687:7687 \
   --env NEO4J_PLUGINS='["bloom"]' \
   --volume=$HOME/neo4j/licenses:/licenses \
   neo4j:5.20.0

|---|--------------|
| | 包含许可证文件的文件夹。 |

相关推荐
木雷坞2 小时前
K8s GPU 推理服务 ImagePullBackOff 排查与预热
云原生·容器·kubernetes·gpu算力
萧行之4 小时前
Docker部署Loki+Grafana+Vector实现全服务器日志监控(含N8N/SSH/Fail2ban监控)
服务器·docker·grafana
人工智能培训5 小时前
工程科研中的AI应用:结构力学分析技巧
人工智能·深度学习·机器学习·docker·容器
计算机安禾5 小时前
【Linux从入门到精通】第35篇:容器化技术预备——Docker安装与基本概念
linux·运维·docker
子木HAPPY阳VIP5 小时前
信创UOS,Docker 完整操作部署(Dockerfile部署方式)&排错整合
linux·运维·redis·nginx·docker·容器·tomcat
AOwhisky5 小时前
Kubernetes调度与服务暴露:从“定时任务”到“服务发现”的完全指南
linux·运维·云原生·容器·kubernetes·服务发现
Cyber4K6 小时前
【Kubernetes专项】温故而知新,重温技术原理(6)
云原生·容器·kubernetes
AI服务老曹6 小时前
架构实战:基于 GB28181 与 RTSP 的异构设备统一接入方案,深度解析 Docker 化 AI 视频管理平台
人工智能·docker·架构
叶总没有会6 小时前
Docker:项目部署
运维·docker·容器
爱学习 爱分享7 小时前
docker 本地装瀚高 4.5 数据库
数据库·docker·容器