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
相关推荐
Fireworkitte3 小时前
如何使用 Dockerfile 创建自定义镜像
运维·docker·容器
heart000_15 小时前
如何用 eBPF 实现 Kubernetes 网络可观测性?实战指南
网络·云原生·容器·kubernetes
Pseudo…6 小时前
容器技术与Docker环境部署
docker·微服务·容器
IT成长日记6 小时前
【Docker基础】Docker镜像管理:docker commit详解
运维·docker·容器·docker commit
IT成长日记6 小时前
【Docker基础】Docker镜像管理:docker build详解
运维·docker·容器·docker build
Byte Beat7 小时前
常用 Docker 命令整理
spring cloud·docker
运维技术分享与探索7 小时前
Centos7.6内网离线安装Docker环境和Portainer-博客
linux·运维·docker·容器·portainer
别骂我h10 小时前
容器技术技术入门与Docker环境部署
java·spring cloud·docker
showyoui10 小时前
Dockerfile 最佳实践
容器
最不会程序的程序猿11 小时前
docker执行yum报错Could not resolve host: mirrorlist.centos.org
docker·容器·centos