docker環境中neo4j導入導出
neo4j 官方文檔有說明,使用 neo4j-admin restore / dump 導出和恢復資料庫的時候需要停掉數據,否則會報資料庫正在使用的錯誤:
command failed: the database is in use — stop Neo4j and try again
官方文檔這樣說:
Restore the database graph.db from the backup located in /mnt/backup/graph.db-backup. Note that the database to be restored must be shut down.
neo4j-home> bin/neo4j stop neo4j-home> bin/neo4j-admin restore --from=/mnt/backup/graph.db-backup --database=graph.db --force neo4j-home> bin/neo4j start
但問題是docker容器中是沒辦法停止neo4j進程的,現在進入容器shudown的話,neo4j容器會停掉(docker-run)或者重啟資料庫(docker-compose),所以這裡採用的迂迴的方法:
首先停掉neo4j容器
sudo docker stop neo4j-container
啟動一個帶有TTY新的容器,如果使用了數據持久化,需要使用-v參數掛載data目錄
sudo docker run \ -v $HOME/neo4j/data:/data \ --name neo4j-container-dump \ -it \ neo4j /bin/bash
在這裡執行導入導出命令
#export bin/neo4j-admin dump --database=graph.db --to=data/20200511.dump #import bin/neo4j-admin load --from=data/2019-01-10.dump --database=graph.db --force
執行成功,可以在宿主機data目錄下看到文件了
最後一步一直遇到個錯誤:
Active logical log detected, this might be a source of inconsistencies.
To perform recovery please start database and perform clean shutdown.
還從stack overflow上找到個解決方法:
found workaround. shutdown database open terminal run bin/neo4j console after startup, hit Ctrl+C to shutdown database then, run neo4j-admin dump respectivery
不起作用,回頭一看,新的容器沒帶版本號,默認的是4.0版本,跟我原先的3.5.16不一樣
再看一眼日誌,4.0版本用的還是jdk11,而3.5版本是jdk8,修改dump容器啟動的環境變數設置,或者重新啟動一個指定版本號為3.5.16的容器即可
neo4j這個問題中文資料幾乎沒有,僅有找到這一偏,確實幫了大忙,感謝!
//www.sudops.com/how-to-dump-restore-neo4j-database-in-docker.html