docker mongo
启动mongo
docker run -dit -p 27017:27017 --name localmongo --restart always mongo:4.1
简单操作
进入容器:docker exec -it 容器ID sh
输入指令:mongo
显示数据库: show dbs
使用数据库:use admin
创建用户:
db.createUser({ user: "useradmin", pwd: "adminpassword", roles: [{ role: "userAdminAnyDatabase", db: "admin" }] })
1.use datatest
2.db.createUser({ user: "test", pwd: "adminpassword", roles: [{ role: "readWrite", db: "datatest" }] })
3.auth
mongodb中的用户是基于身份role的,该管理员账户的 role是 userAdminAnyDatabase。 ‘userAdmin’代表用户管理身份,’AnyDatabase’ 代表可以管理任何数据库。
验证第3步用户添加是否成功
db.auth("useradmin", "adminpassword") 如果返回1,则表示成功。
--- 如果连接不上,怀疑是客户端的问题
创建数据库:
1.use datatest
2.db.datatest.insert({"name":"賬號"})
插入数据表示数据库已创建
db 数据库
mycoll 集合
doc 文档
创建索引
以title 字段创建索引,1表示 升序
db.mycoll.createIndex({"title":1},{background:true})
其他启动方式
简化版
docker run --name mongo1 -p 21117:27017 -d mongo --noprealloc --smallfiles
自定义mongo数据路径
docker run --name mongo_rs1 -v ~/test/mongo_sr1:/mongodb -p 37117:27017 -d mongo mongod --logpath /mongodb/mongo.log --logappend --dbpath /mongodb
开启mongo双主配置
docker run --name mongo_rs2 -v ~/test/mongo_sr2:/mongodb -p 37118:27017 -d mongo mongod --logpath /mongodb/mongo.log --logappend --dbpath /mongodb --master --slave --port=27017 --autoresync --source=192.168.118.73:37117
常规,用mongo默认数据路径,并挂载出来
docker run --name mongodb_alpha -d --dns=192.168.1.26 -p 37017:27017 -v /home/devsa_dev/mongo_data/configdb:/data/configdb -v /home/devsa_dev/mongo_data/db:/data/db mongo
角色
Read:允许用户读取指定数据库
readWrite:允许用户读写指定数据库
dbAdmin:允许用户在指定数据库中执行管理函数,如索引创建、删除,查看统计或访问system.profile
userAdmin:允许用户向system.users集合写入,可以找指定数据库里创建、删除和管理用户
clusterAdmin:只在admin数据库中可用,赋予用户所有分片和复制集相关函数的管理权限。
readAnyDatabase:只在admin数据库中可用,赋予用户所有数据库的读权限
readWriteAnyDatabase:只在admin数据库中可用,赋予用户所有数据库的读写权限
userAdminAnyDatabase:只在admin数据库中可用,赋予用户所有数据库的userAdmin权限
dbAdminAnyDatabase:只在admin数据库中可用,赋予用户所有数据库的dbAdmin权限。
root:只在admin数据库中可用。超级账号,超级权限
dockerfile 执行
执行mongo dockerfile
docker build -t mongo3.4 -f mongo-3_4-Dockerfile .
文件路径