Neo4j在win下安装教程(docker环境)

1. 安装命令

1.1 基于正式neo4j安装--不用

bash 复制代码
docker run --name neo4j-container -p 7474:7474 -p 7687:7687 -d neo4j

1.2 基于community安装

需要部署两个Neo4j,一个正式库prod,一个测试库dev。

neo4j默认监听7474(HTTP-也就是浏览器端口)和7687(Bolt-也就是服务器接口)端口。

首先需要明确的是,通过docker部署的服务,容器内部的7474和7687端口不会冲突 ,因为Docker的端口映射机制是基于宿主机****端口->容器端口的隔离。

1.2.1 端口映射原理

  • **容器内部端口:**每个 Neo4j 容器内部默认监听 <font style="background-color:rgb(242,243,245);">7474</font>(HTTP)和 <font style="background-color:rgb(242,243,245);">7687</font>(Bolt)端口。
  • **宿主机****端口:**通过 <font style="background-color:rgb(242,243,245);">-p</font> 参数将宿主机的端口映射到容器的端口。例如:
    • 第一个容器:<font style="background-color:rgb(242,243,245);">-p 7474:7474</font>(宿主机7474 → 容器7474)
    • 第二个容器:<font style="background-color:rgb(242,243,245);">-p 7475:7474</font>(宿主机7475 → 容器7474)

关键点: 即使容器内部都使用 <font style="background-color:rgb(242,243,245);">7474</font><font style="background-color:rgb(242,243,245);">7687</font>,只要宿主机的映射端口不同(如 <font style="background-color:rgb(242,243,245);">7475</font><font style="background-color:rgb(242,243,245);">7688</font>),两个容器就能同时运行且互不冲突。

1.2.2 两种创建方式

1.2.2.1 绑定挂载(windows绝对路径-需要手动创建路径)
plain 复制代码
docker run --name neo4j-dev -p 17475:7474 -p 17688:7687 -v C:\neo4j\dev:/data -v C:\neo4j\dev:/logs -d neo4j :community
  • 优点:
    • 直观可控:可以直接在宿主机的文件系统中查看和修改数据文件(如 <font style="background-color:rgb(242,243,245);">C:\neo4j\data2</font>)。
    • 适合调试:方便直接修改配置文件(如 <font style="background-color:rgb(242,243,245);">neo4j.conf</font>)或检查日志文件(如 <font style="background-color:rgb(242,243,245);">neo4j.log</font>)。
    • 完全控制目录位置:自由选择宿主机的存储路径。
  • 缺点:
    • 需手动处理目录权限:如果宿主机目录权限设置不当,容器可能无法写入。
    • 跨平台兼容性问题:Windows 路径格式(如 <font style="background-color:rgb(242,243,245);">C:\...</font>)在 Docker 中需要特别处理,可能与其他系统不兼容。
    • 依赖宿主目录存在性:必须预先手动创建目录,否则启动失败(尤其是 Windows)。

适用场景:

  • 需要直接操作宿主机文件(如开发阶段修改配置文件或分析日志)。
  • 数据需存放在宿主机的特定位置(如已有存储系统需要挂载)。
1.2.2.2 Docker卷(不需要手动创建路径)-本次使用的方案

正式:

plain 复制代码
docker run --name neo4j-prod -p 17474:7474 -p 17687:7687 -v neo4j_prod_data:/data -v neo4j_prod_logs:/logs -d neo4j:community

测试:

plain 复制代码
docker run --name neo4j-dev -p 17475:7474 -p 17688:7687 -v neo4j_dev_data:/data -v neo4j_dev_logs:/logs -d neo4j:community
  • 优点:
    • 自动管理:Docker 会自动创建卷并处理文件权限,无需手动干预。
    • 跨平台一致性:路径格式统一(如 <font style="background-color:rgb(242,243,245);">/data</font>),避免 Windows/Linux 路径差异问题。
    • 适合生产环境:数据由 Docker 托管,更安全且支持加密、备份等高级功能。
    • 容器无缝迁移:容器重建或迁移时,卷可以快速复用。
  • 缺点:
    • 隐藏文件位置:默认卷存储在 Docker 的私有路径中(如 <font style="background-color:rgb(242,243,245);">C:\ProgramData\Docker\volumes</font>),需要命令行才能查看。
    • 不直接修改文件:需通过容器内部或 Docker 命令访问数据,对普通用户不够直观。

适用场景:

  • 生产环境或需要自动化部署的场景。
  • 无需直接访问底层数据文件,注重数据安全性和一致性。

推荐使用哪种?--本次直接使用Docker卷的方式进行创建

  • 推荐:生产环境使用 Docker 卷,开发环境使用绑定挂载:
    • 生产环境 → 优先选 Docker 卷 安全便捷,避免路径和权限问题,适合长期运行的稳定服务。
    • 开发环境 → 优先选绑定挂载 方便直接查看和修改配置文件、日志文件,适合调试和测试。

2. 访问

http://localhost:7474

第一次进入页面,需要输入用户名密码neo4j/neo4j,并且需要设置新密码

3. 服务起上的用户密码

neo4j/neo4jneo4j

4. 停止和启动 Neo4j 容器

要停止正在运行的 Neo4j 容器,可以使用以下命令:

bash 复制代码
docker stop neo4j-container

要再次启动容器,使用:

bash 复制代码
docker start neo4j-container
相关推荐
小鸡,啄米8 分钟前
centos9安装docker 配置docker代理
运维·docker·容器
遇见火星2 小时前
jenkins流水线常规配置教程!
运维·docker·jenkins
LunarCod3 小时前
Ubuntu使用Docker搭建SonarQube企业版(含破解方法)
linux·运维·服务器·ubuntu·docker·开源·sonarqube
野指针121385 小时前
部署GraphRAG配置Neo4j实现知识图谱可视化【踩坑经历】
知识图谱·neo4j·graphrag
ZHOU_WUYI5 小时前
使用 Docker 部署 React + Nginx 应用教程
nginx·react.js·docker
小锋学长生活大爆炸6 小时前
【教程】Docker更换存储位置
运维·docker·容器
川石教育10 小时前
测试工程师如何学会Kubernetes(k8s)容器知识
云原生·容器·kubernetes·kubernetes容器·kubernetes教程
从零开始学习人工智能10 小时前
在 Neo4j 中实现向量化存储:从文本到高效语义搜索
neo4j
楠奕10 小时前
python中使用neo4j
开发语言·python·neo4j
Ailovelearning10 小时前
neo4j框架:ubuntu系统中neo4j安装与使用教程
数据库·neo4j