前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Python爬虫之mongodb的权限管理

Python爬虫之mongodb的权限管理

作者头像
海仔
发布2020-09-23 11:59:47
7440
发布2020-09-23 11:59:47
举报
文章被收录于专栏:海仔技术驿站海仔技术驿站

Mongodb的权限管理

学习目标

1.了解 mongodb的权限管理


1. 为什么要进行权限管理的设置

刚安装完毕的mongodb默认不使用权限认证方式启动,与MySQL不同,mongodb在安装的时候并没有设置权限,然而公网运行系统需要设置权限以保证数据安全,所以我们要学习mongodb的权限管理

2. mongodb的权限管理方案

  • MongoDB是没有默认管理员账号,所以要先添加管理员账号,并且mongodb服务器需要在运行的时候开启验证模式
    • 用户只能在用户所在数据库登录(创建用户的数据库),包括管理员账号。
    • 管理员可以管理所有数据库,但是不能直接管理其他数据库,要先认证后才可以。

3. mongodb超级管理员账号的创建

3.1 创建超级用户

进入mongo shell

代码语言:javascript
复制
sudo mongod

使用admin数据库(超级管理员账号必须创建在该数据库上)

代码语言:javascript
复制
use admin

创建超级用户

代码语言:javascript
复制
db.createUser({"user":"python","pwd":"python","roles":["root"]})

创建成功会显示如下信息

代码语言:javascript
复制
Successfully added user: { "user" : "python", "roles" : [ "root" ] }

退出mongo shell

代码语言:javascript
复制
exit
3.2 以权限认证的方式启动mongodb数据库
代码语言:javascript
复制
sudo mongod --auth

启动之后在启动信息中会有如下信息,说明mongodb以权限认证的方式启动成功

代码语言:javascript
复制
[initandlisten] options: { security: { authorization: "enabled" } }
3.3 登录验证

此时再使用数据库各命令的时候会报权限错误,需要认证才能执行相应操作、

代码语言:javascript
复制
use admin
db.auth('python','python')
  • python用户是创建在admin数据库上的所以必须来到admin数据库上进行认证
  • 认证成功会返回1,失败返回0

4. 创建普通用户

4.1 在使用的数据库上创建普通用户

1.选择需要创建用户的数据库

代码语言:javascript
复制
use test1
  1. 创建用户
代码语言:javascript
复制
db.createUser("user":"user1", "pwd":"pwd1", roles:["read"])
创建普通用户user1,该用户在test1上的权限是只读
db.createUser("user":"user1", "pwd":"pwd1", roles:["readWrite"])
创建普通用户user1,该用户在test1上的权限是读写
4.2 在admin用户数据库上创建普通用户
代码语言:javascript
复制
use admin
db.createUser({"user":"python1", "pwd":"python1", roles:[{"role":"read","db":"dbname1"},{"role":"readWrite","db":"dbname2"}
]})

在admin上创建python1用户,python1用户的权限有两个,一个再dbname1上的只读,另一个是在dbname2上的读写

5. 查看创建的用户

代码语言:javascript
复制
show users
{
	"_id" : "admin.python",
	"user" : "python",
	"db" : "admin",
	"roles" : [
		{
			"role" : "root",
			"db" : "admin"
		}
	]
}

6. 删除用户

6.1 进入账号数据所在的数据库
代码语言:javascript
复制
use db_name
6.2 删除用户
代码语言:javascript
复制
db.dropUser('python')

小结

  1. 了解mongodb的权限管理
  2. 熟悉创建用户的相应流程

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2020-09-20 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • Mongodb的权限管理
    • 1. 为什么要进行权限管理的设置
      • 2. mongodb的权限管理方案
        • 3. mongodb超级管理员账号的创建
          • 3.1 创建超级用户
          • 3.2 以权限认证的方式启动mongodb数据库
          • 3.3 登录验证
        • 4. 创建普通用户
          • 4.1 在使用的数据库上创建普通用户
          • 4.2 在admin用户数据库上创建普通用户
        • 5. 查看创建的用户
          • 6. 删除用户
            • 6.1 进入账号数据所在的数据库
            • 6.2 删除用户
        • 小结
        相关产品与服务
        访问管理
        访问管理(Cloud Access Management,CAM)可以帮助您安全、便捷地管理对腾讯云服务和资源的访问。您可以使用CAM创建子用户、用户组和角色,并通过策略控制其访问范围。CAM支持用户和角色SSO能力,您可以根据具体管理场景针对性设置企业内用户和腾讯云的互通能力。
        领券
        问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档