欢迎光临
我们一直在努力

Mongodb安装以及账户管理(一)

一、MongoDB安装

1. wget http://fastdl.mongodb.org/linux/mongodb-linux-x86_64-2.4.1.tgz
   wget http://downloads.mongodb.org/src/mongodb-src-r2.4.1.tar.gz

  tar xzvf mongodb-linux-x86_64-2.4.1.tgz
mv mongodb-linux-x86_64-2.4.1 /usr/local/mongodb
 
  建立数据目录以及日志目录
  mkdir -p /data/mongodb/db1
mkdir -p /data/mongodb/logs

  启动mongodb,如果要保留原来的日志,还需要使用 –logappend 选项

  /usr/local/mongodb/bin/mongod –port 27017 –dbpath /data/mongodb/db1/ –logpath /data/mongodb/logs/m1.log –logappend    &
  或者作为守护进程方式启动

  /usr/local/mongodb/bin/mongod –port 27017 –dbpath /data/mongodb/db1/ –logpath /data/mongodb/logs/m1.log –logappend –fork
  再或者以配置文件方式启动

 cat /etc/mongodb.conf
 port = 27017
fork = true
dbpath = /data/mongodb/db1/
logpath = /data/mongodb/logs/m1.log
logappend = true
#auth = true
 
/usr/local/mongodb/bin/mongod -f /etc/mongodb.conf
  
netstat -ntpl |grep :3306                                                                                         tcp                0            0 0.0.0.0:3306
                             0.0.0.0:*                                     LISTEN            1499/mongod

 cat /data/mongodb/db1/mongod.lock                                                                        
    1499

 mongodb 的停止

/usr/local/mongodb/bin/mongod –port 27017 –dbpath /data/mongodb/db1/ –logpath    /data/mongodb/logs/m1.log –shutdown
或者 kill PID ,千万不能在运行的mongodb发送 kill -9 信号 这样会导致mongodb损坏

再或者
/usr/local/mongodb/bin/mongod -f /etc/mongodb.conf –shutdown

二、配置mongodb

  1.添加用户
  先连接mongodb  /usr/local/mongodb/bin/mongo 127.0.0.1:27017
 
  首先切换到admin库,先建立一个管理员账号 没有加auth情况下
> use admin
> db.addUser(“root”,”123456″);

这样就说明 已经成功建立了,然后我们试一下权限。

> show collections    
system.indexes    
system.users

在没有加–auth的情况下 可以正常访问admin喜爱默认的两个表。
> db.system.users.find()
{ “_id” : ObjectId(“5151c8fced3092583ca7c6a5”), “user” : “root”, “readOnly” : false, “pwd” :

“34e5772aa66b703a319641d42a47d696” }

把在配置文件或者启动项加上–auth选项再次进入./mongo

> show collections
Wed Mar 27 00:42:57.554 JavaScript execution failed: error: {
        “$err” : “not authorized for query on test.system.namespaces”,
        “code” : 16550

可以看出已经没有访问权限了

我们用自己的密码登陆
> db.auth(‘root’,’123456′)
1
返回1说明验证成功!

再show collections下就成功了。

我们登录其它表通过测试发现其他的也需要验证
试试super admin登录
> db.auth(‘root’,’123456′)
Error: 18 { ok: 0.0, errmsg: “auth fails” }
0

返回0验证失败。
其实super admin必须从admin那么登录 然后 再use其它表才可以。

如果想单独访问一个表,用独立的用户名,就需要在那个表里面建相应的user。

 /usr/local/mongodb/bin/mongo
MongoDB shell version: 2.4.1
connecting to: test
> use admin
switched to db admin
> db.auth(‘root’,’123456′)
1
> use test
switched to db test

> db.addUser(‘test’,’123456′)
{
        “user” : “root”,
        “readOnly” : false,
        “pwd” : “34e5772aa66b703a319641d42a47d696”,
        “_id” : ObjectId(“5151d27c4836c71202b7ac37”)
}

再登陆 看看

[root@localhost ~]# /usr/local/mongodb/bin/mongo
MongoDB shell version: 2.4.1
connecting to: test
> use test
switched to db test
> db.auth(‘test’,’123456′)
1
>

返回1说明验证成功。

赞(0)
【声明】:本博客不参与任何交易,也非中介,仅记录个人感兴趣的主机测评结果和优惠活动,内容均不作直接、间接、法定、约定的保证。访问本博客请务必遵守有关互联网的相关法律、规定与规则。一旦您访问本博客,即表示您已经知晓并接受了此声明通告。