环境:
- MongoDB 4.0.10
- Docker
查看MongoDB版本命令:db.version();
背景:最近在处理MongoDB的一些数据,不过因为安全问题,所以端口没对外开放出来,所以不用使用比如Navicat这些客户端软件,所以执行脚本就要到命令窗口执行,执行脚本不长还好,太长的话,复制到shell窗口一大串要很长时间
因为装在docker里,所以直接使用命令,先查看MongoDB镜像ID
代码语言:javascript复制docker ps
找到MongoDB的镜像后,进入镜像,0ac56ae108c0
为容器ID
docker exec -it 0ac56ae108c0 bash
因为要执行一大串的脚本,黏贴到shell窗口里,就要很长时间,所以问题来了,直接复制一大串代码执行的方法太慢了,只能看看能不能用命令执行文件,将代码弄到一个js文件里,然后用命令执行
先从MongoDB数据库导出js脚本,然后在js脚本文件里,在其最前面加上连接数据库的代码:
代码语言:javascript复制conn = new Mongo("127.0.0.1:27017");
db = conn.getDB("test");
然后保存,使用docker命令复制js文件到MongoDB容器里
代码语言:javascript复制docker cp /opt/test.js 0ac56ae108c0:/opt/test.js
然后使用mongo
命令执行js脚本,注意是要到MongoDB容器里执行
# 到/opt目录
cd /opt
# 执行js脚本
mongo test.js
总结:本博客需要一些docker基础,没遇到这个问题的读者,可能不太理解,因为要导入很多数据导MongoDB,所以先在Navicat这些工具导出js脚本,然后因为shell窗口复制执行太慢了,所以先在js代码里加上连接MongoDB的代码,然后docker复制文件到MongoDB容器里,在使用命令直接执行js文件,速度很快