MongoDB
- Official site: mongodb.org
- Install: 使用官方提供的源:ubuntu安装mongodb的教程
- Start:
sudo service mongod start
- Log:
/var/log/mongodb/mongod.log
Tutorials
mongo [--port ][--host ]
进入mongodb命令行, 默认port为27017
, hostlocalhost
- 命令行支持javascript语法
- 帮助:
help
- 显示db列表:
show dbs
或show databases
- 显示当前db:
db
- 切换db:
use dbname
可以直接切换到一个不存在的db来插入数据, 相当于创建. - 显示当前db的collection列表
show collections
或show tables
- 插入数据,注意collection可以是事先不存在的, 比如下面的
testData
,命令执行后会自动创建j = { name : "mongo" } k = { x : 3 } db.testData.insert( j ) db.testData.insert( k ) //或者循环插入 for (var i = 1; i <= 25; i++) db.testData.insert( { x : i } )
- 查看插入的数据:
db.testData.find()
. - mongodb要求每条数据都要有
_id
, 如果没指定, 会自动创建一个. find()
或其它获取方式的返回数据, 称为cursor
, 可对此结果进行操作, 比如var c = db.testData.find() while ( c.hasNext() ) printjson( c.next() )
- 查看索引:
db.testData.getIndexes()
- 设置索引:
db.testData.createIndex({ "your_index": 1})//1为正序,-1为逆序
- 设置一段时间后自动删除数据: 官网文档
db.log_events.createIndex( { "createdAt": 1 }, { expireAfterSeconds: 3600 } ) //表示在文档索引"createAt"设定的时间值之后3600秒自动删除此条文档
Auth
- mongodb 启动时加
--auth
才开启用户认证; - mongodb 开启认证后, 默认 admin 数据库没有用户,此时可添加用户及相应的 role , 一般是
userAdminAnyDatabase
,即能对所有数据库进行用户管理;use admin; db.createUser( { user: "myUserAdmin", pwd: "abc123", roles: [ { role: "userAdminAnyDatabase", db: "admin" } ] } )
- admin 数据库里有用户后,后续操作就需要认证。用户管理需要以 admin 数据库登录再
use dbname
,然后用用户管理函数操作 - 可以给用户添加
dbAdminAnyDatabase
角色以操作所有数据库角色(userAdmin 只操作当前数据库用户)。 - 客户端或 shell 登录时如果指定了数据库名称,那么就只能用该数据库里的用户登录(
db.getUsers()
里列出的)。 - 查看数据库状态的角色是
clusterMonitor
, 给用户添加角色db.grantRolesToUser( "myuser", [ { role: "clusterMonitor", db:"admin"} ] );
Tools
Mongoose
- Mongoose: MongoDB ODM
- schema
Tips
- mongo 的 docker 镜像,在 OSX/Windows 下不能用容器外存储。
- mongo 的 collections 数量限制上限为命名空间数量,命名空间包括 collection 名称与索引名称, 上限大概为24000个,可调整。但 新的 WiredTiger 引擎不受此限制
- mongo 默认的 _id 是默认索引,前四字节为 unixtime 秒数,即
ObjectId(“59d0a08032b1ec00019f70b9”
的59d0a080
为 unixtime, 可用此来按插入时间操作数据, 比如db.testData.find({"_id" : { $lt: ObjectId("59d0a0800000000000000000")} })
- mongo3 删除数据或者表并不会释放磁盘空间,释放磁盘空间可以删除数据库
db.dropDatabase()
, 或者使用db.repairDatabase()
, 但是后者必须空余的磁盘空间大于数据库实际大小才能成功。释放磁盘空间方法参考:https://yq.aliyun.com/articles/606187