平时的工作中,我们可能需要将一个数据库的文件导出,然后再将这个文件导入到另一个数据库中,实现数据库的迁移。
本文中主要介绍neo4j的官方管理工具neo4j-admin,来对neo4j数据库文件进行导入和导出。
1.文件导出
(1).停止服务
进入到需导出文件的neo4j的bin目录下,执行 ./neo4j stop 命令先停止服务。
bash
./neo4j stop
(2).导出文件
bash
neo4j-admin database dump myneo4jdb --to-path=/var/lib/neo4j/backups/
以上的命令会将myneo4jdb这个数据库导入到 /var/lib/neo4j/backups/这个目录下。如果该目录不存在,需要自己创建。最后会导出.dump后缀的数据文件。
(3).启动服务
数据库文件导出完成后,就可以启动服务了。
bash
./neo4j start
(4).docker导出
如果我们的neo4j数据库是使用docker部署的话,以下是使用docker命令的方式来导出文件。
停止服务
bash
docker stop neo4j_service
导出文件
bash
docker run --interactive --tty --rm \
-v=$(pwd)/db-data:/var/lib/neo4j/data \
-v=$(pwd)/db-export:/var/lib/neo4j/backups/ \
neo4j:5.26.2 \
neo4j-admin database dump myneo4jdb --to-path=/var/lib/neo4j/backups/
以上docker命令中宿主机和docker容器映射挂载了两个目录:1.neo4j数据库数据文件的挂载目录。2.导出完成后导出文件存放的挂载目录。可以看出本例中使用的是5.26.2版本的neo4j数据库镜像。导出命令执行完成后,我们可以在宿主机的db-export目录下看到导出的文件。
启动服务
bash
docker start neo4j_service
2.文件导入
(1).停止服务
bash
./neo4j stop
(2).导入文件
bash
neo4j-admin database load --from-path=/var/lib/neo4j/import/ myneo4jdb --overwrite-destination=true
上述的导入命令是把/var/lib/neo4j/import/目录下的数据库文件导入到目标库,导入后数据库的名称是myneo4jdb,参数**--overwrite-destination=true**的作用是,如果数据库中已经存在了myneo4jdb数据库,则会将myneo4jdb覆盖。
(3).启动服务
./neo4j start
(4).docker导入
停止服务
bash
docker stop neo4j_service
导入文件
bash
docker run --rm -it \
-v=$(pwd)/db-data:/var/lib/neo4j/data \
-v=$(pwd)/import:/var/lib/neo4j/import \
neo4j:5.26.2 \
neo4j-admin database load --from-path=/var/lib/neo4j/import/ myneo4jdb --overwrite-destination=true
以上docker命令中宿主机和docker容器映射也挂载了两个目录:1.neo4j数据库数据文件的挂载目录。2.需导入数据库文件放置的目录。我们需要把要导入的数据库文件,放到宿主机的import目录下。
启动服务
bash
docker start neo4j_service
3.导入特定账户的数据库
有时候我们导入的neo4j数据库可能是某个特定账户的,需要通过账户和密码才能访问到这个数据库。对于这种情况,我们先使用帐号通过Cypher Shell登录neo4j后,然后创建一个空的目标库,最后在导入数据库时通过**--overwrite-destination=true**的参数,将创建的空库给覆盖掉。需要注意的是导入数据库的名称和创建的空库的名称要一样。
(1).通过Cypher Shell登录neo4j
进入neo4j数据库bin目录下,执行./cypher-shell 命令后,再输入账号和密码,即可登录neo4j数据库。
bash
./cypher-shell

(2).创建目标空库
bash
-- 登录后,先切换到system数据库
:use system;
-- 尝试创建数据库
create database myneo4jdb;
-- 查看数据库
show databases;

(3).覆盖目标空库
对于以上步骤2中创建的空数据库,我们再使用数据库导出文件将这个空数据覆盖掉就可以了。
bash
neo4j-admin database load --from-path=/var/lib/neo4j/import/ myneo4jdb --overwrite-destination=true