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'); //刚添加的用户可以登录。
相关文章推荐
- mongo数据库基本操作--python篇
- Python操作Mongo数据库
- python mongo数据库出错解决及pymongo操作
- mongo数据库基本操作--python篇
- python学习之数据库操作(mysql_ubuntu版)
- [Python]MySQLdb for Python使用指南/Python的数据库操作
- python 数据库操作
- [Python]MySQLdb for Python使用指南/Python的数据库操作
- MySQLdb for Python使用指南/Python的数据库操作
- Python 3.x之数据库框架Sqlalchemy操作SQlite(续)
- python 数据库blob数据操作
- Python学习笔记十(pymssql数据库操作)
- Python Sqlite3数据库相关操作
- python中cursor操作数据库
- python+mysql 操作数据库出现的中文编码问题
- 使用Python操作MSSQL数据库.
- MySQLdb for Python使用指南/Python的数据库操作
- [Python]MySQLdb for Python使用指南/Python的数据库操作
- 学习python 第三季:编写简单简单连接数据库并执行查询操作
- 【问题】如何在Python中操作数据库