您的位置:首页 > 编程语言 > Python开发

Python中操作mongo数据库

2016-12-12 14:08 351 查看

一、Ubuntu中安装Mongodb

1. apt-get update
2. apt-get install mongodb
3. vim /etc/mongodb.conf
将如下配置修改:
#bind_ip = 127.0.0.1   //注释此行
auth = true       //将此行前的注释去掉(之后连接数据库需要验证)
4. 防火墙开放27017端口
iptables -A INPUT -p tcp -m state --state NEW -m tcp --dport 27017 -j ACCEPT
5. 重启mongodb


二、安装 Python操作Mongodb的库pymongo

pip install pymongo


Python中使用pymongo

mongodb是没有默认管理员账号,所以要先添加管理员账号,在开启权限认证。

切换到admin数据库,添加的账号才是管理员账号。

用户只能在用户所在数据库登录,包括管理员账号。

管理员可以管理所有数据库,但是不能直接管理其他数据库,要先在admin数据库认证后才可以。这一点比较怪

[root@localhost zhangy]# mongo
MongoDB shell version: 2.4.6
connecting to: tank
> show dbs;           //显示所有数据库失败,因为还没有认证
Wed Dec  4 06:39:50.925 listDatabases failed:{ "ok" : 0, "errmsg" : "unauthorized" } at src/mongo/shell/mongo.js:46
> db.auth('tank','test');    //认证失败,因为这个用户不属于tank这个数据库
Error: 18 { code: 18, ok: 0.0, errmsg: "auth fails" }
0
> use admin        //切换到admin数据库
switched to db admin
> db.auth('tank','test');   //在admin数据库认证成功
1
> use tank;           //切换到tank数据库
switched to db tank
> show collections;   //不会在提示没有权限了
contact
system.indexes
users
五,添加普通用启
查看复制打印?
> use tank;
switched to db tank
> db.addUser('tank1','test');     //为tank数据库添加了一个可读写用户tank1
{
"_id" : ObjectId("529e5f8474b4c660718a70f3"),
"user" : "tank1",
"readOnly" : false,
"pwd" : "35dd47abff098f5b4f0b567db8edeac5"
}
> db.addUser('tank2','test',true);  //为tank数据库添加了一个只读用户tank2
{
"user" : "tank2",
"readOnly" : true,
"pwd" : "1792916c544d247538ded52e6df7b887",
"_id" : ObjectId("529e67553992b24438d5e315")
}
> exit    //退出
bye
[root@localhost zhangy]# mongo
MongoDB shell version: 2.4.6
connecting to: tank
> db.auth('tank1','test');    //刚添加的用户可以登录。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  python