博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Mongodb初探
阅读量:5917 次
发布时间:2019-06-19

本文共 2588 字,大约阅读时间需要 8 分钟。

下载

wget https://fastdl.mongodb.org/linux/mongodb-linux-x86_64-rhel62-3.2.3.tg

解压后修改名称

tar xvzf mongodb-linux-x86_64-rhel62-3.2.3.tg

mv mongodb-linux-x86_64-rhel62-3.2.3.tg mongodb

mv mongodb /usr/local/


mkdir /data/db



./mongod

#启动安全模式

#./mongod --auth >> mongodb.log & 

启动shell

./mongo


简单插入:

> db.test.insert({"name":"cctv","time":"1952"})

WriteResult({ "nInserted" : 1 })

查找

> db.test.find()

{ "_id" : ObjectId("56c812e8c3173d7c3942bf94"), "type" : "Fuck" }

{ "_id" : ObjectId("56c81e9a2b323f6d772f237b"), "name" : "cctv", "time" : "1952" }

更新 update方法的第一个参数为“查找的条件”,第二个参数为“更新的值”

>db.test.update({"name":"cctv"},{"name":"China-CNTV"})

WriteResult({ "nMatched" : 1, "nUpserted" : 0, "nModified" : 1 })

>

删除

remove中如果不带参数将删除所有数据,呵呵,很危险的操作,在mongodb中是一个不可撤回的操作,三思而后行

> db.test.remove({"name":"China-CNTV"})

WriteResult({ "nRemoved" : 2 })

> db.test.find()

{ "_id" : ObjectId("56c812e8c3173d7c3942bf94"), "type" : "Fuck" }

>




启用认证


mongod 启动默认没有开启权限,你需要指定 –auth 启动,或者在配置文件中设置security.authorization 为 “enabled”

创建用户


db.createUser(user, writeConcern)


    文档 http://docs.mongodb.org/manual/reference/method/db.createUser/#db.createUser


user格式


{ user: "<name>",

  pwd: "<cleartext password>",

  customData: { <any information> },

  roles: [

    { role: "<role>", db: "<database>" } | "<role>",

    ...

  ]

}


writeConcern:


例如 {w: “majority”, j: true, wtimeout: 5000}


    w选项:允许的值分别是 1、0、大于1的值、”majority”、;

    j选项:确保mongod实例写数据到磁盘上的journal(日志),这可以确保mongd以外关闭不会丢失数据。设置true启用。

    wtimeout:指定一个时间限制,以毫秒为单位。wtimeout只适用于w值大于1。


Built-In Roles(内置角色):


    数据库用户角色:read、readWrite;

    数据库管理角色:dbAdmin、dbOwner、userAdmin;

    集群管理角色:clusterAdmin、clusterManager、clusterMonitor、hostManager;

    备份恢复角色:backup、restore;

    所有数据库角色:readAnyDatabase、readWriteAnyDatabase、userAdminAnyDatabase、dbAdminAnyDatabase

    超级用户角色:root

    // 这里还有几个角色间接或直接提供了系统超级用户的访问(dbOwner 、userAdmin、userAdminAnyDatabase)

    内部角色:__system


creatUser例子


创建超级管理员


use admin

db.createUser({

    user:"username",

    pwd:"password",

    roles:["root"]

})


在products数据库创建accountAdmin01用户,拥有readWrite权限,对admin数据库拥有clusterAdmin跟readAnyDatabase权限


use products

db.createUser( { "user" : "accountAdmin01",

                 "pwd": "cleartext password",

                 "customData" : { employeeId: 12345 },

                 "roles" : [ { role: "clusterAdmin", db: "admin" },

                             { role: "readAnyDatabase", db: "admin" },

                             "readWrite"

                             ] },

               { w: "majority" , wtimeout: 5000 } )


登录


use collectionName

db.auth("username",'password")


查看用户


show users


删除用户


db.dropUser("username")


更改用户密码


db.changeUserPassword("username","password")


更新用户


db.createUser(user, writeConcern)





新建或者切换数据库

use dbname


切换到admin


use admin

      本文转自flyingzf  51CTO博客,原文链接:http://blog.51cto.com/flyingzf/1743678,如需转载请自行联系原作者

你可能感兴趣的文章
oracle 字符串排序,数字优先排序
查看>>
【转】网络中的AS自治域
查看>>
写入临时日志到文本
查看>>
printf("%f\n",5);
查看>>
从头开始学JavaScript (八)——变量
查看>>
reactor模式学习
查看>>
自己封装的CMusic类 【转】
查看>>
magento登陆
查看>>
为什么多数游戏服务端是用 C++ 来写
查看>>
最大子数组和
查看>>
Php5.5新特性 Generators详解
查看>>
JQuery Sizzle引擎源代码分析
查看>>
tar 报错gzip: stdin: not in gzip format
查看>>
javascript 在线文本编辑器
查看>>
第38周星期五小结
查看>>
最近新出的C++右值引用的意思
查看>>
Plus One @LeetCode
查看>>
jquery奇怪的问题
查看>>
294. Flip Game II
查看>>
使用EasyUI实现加入和删除功能
查看>>