激情久久久_欧美视频区_成人av免费_不卡视频一二三区_欧美精品在欧美一区二区少妇_欧美一区二区三区的

服務器之家:專注于服務器技術及軟件下載分享
分類導航

Mysql|Sql Server|Oracle|Redis|MongoDB|PostgreSQL|Sqlite|DB2|mariadb|Access|數據庫技術|

服務器之家 - 數據庫 - MongoDB - MongoDB數據庫授權認證的實現

MongoDB數據庫授權認證的實現

2022-02-10 17:38Jiangxl~ MongoDB

本文主要介紹了MongoDB數據庫授權認證的實現,文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下

1.與用戶相關的命令

  • db.auth() 將用戶驗證到數據庫。
  • db.changeuserpassword() 更改現有用戶的密碼。
  • db.createuser() 創建一個新用戶。
  • db.dropuser() 刪除單個用戶。
  • db.dropallusers() 刪除與數據庫關聯的所有用戶。
  • db.getuser() 返回有關指定用戶的信息。
  • db.getusers() 返回有關與數據庫關聯的所有用戶的信息。
  • db.grantrolestouser() 授予用戶角色及其特權。
  • db.removeuser() 已過時。從數據庫中刪除用戶。
  • db.revokerolesfromuser() 從用戶中刪除角色。
  • db.updateuser() 更新用戶數據。

2.配置mongodb登陸授權認證

2.1.創建一個用戶

?
1
2
3
4
5
6
7
8
> use admin
> db.createuser(
{
   user: "admin",
   pwd: "123456",
   roles: [ { role: "root", db: "admin" } ]         //指定角色為root,表示管理員
}
> db.getusers()

MongoDB數據庫授權認證的實現

2.2.修改配置文件啟用用戶認證

?
1
2
3
[mongo@mongodb-1 ~]$ vim /data/mongodb_cluster/mongodb_27017/conf/mongodb.yml
security:
  authorization: enabled

2.3.重啟mongodb

?
1
2
3
4
5
6
[mongo@mongodb-1 ~]$ mongod -f /data/mongodb_cluster/mongodb_27017/conf/mongodb.yml --shutdown
killing process with pid: 17899
[mongo@mongodb-1 ~]$ mongod -f /data/mongodb_cluster/mongodb_27017/conf/mongodb.yml
about to fork child process, waiting until server is ready for connections.
forked process: 18511
child process started successfully, parent exiting

2.4.使用口令登陸mongodb

?
1
2
3
4
5
6
[mongo@mongodb-1 ~]$ mongo -uadmin -p123456
mongodb shell version v4.0.14
connecting to: mongodb://127.0.0.1:27017/?gssapiservicename=mongodb
implicit session: session { "id" : uuid("ae65176e-ac6b-4906-b621-496996381417") }
mongodb server version: 4.0.14
> show dbs

使用口令登陸后會發現最后一個警告信息也會消失

MongoDB數據庫授權認證的實現

3.授權用戶并賦予多個權限

mongodb可以創建多個用戶并針對不同的庫進行不同的操作

3.1.創建用戶并制造數據

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
1.創建用戶
[mongo@mongodb-1 ~]$ mongo -uadmin -p123456
> db.createuser(
...   {
...     user: "mytest",
...     pwd: "123456",
...     roles: [ { role: "readwrite", db: "test" },     //可讀可寫
...              { role: "read", db: "test2" }   ]                  //可讀
...   }
... )
 
 
2.插入數據
test庫
> use test
> db.test.insert({"name":"xiaoming","age":10})
> db.test.insert({"name":"xiaohong","age":10})
> db.test.insert({"name":"xiaolan","age":10})
 
test2庫
> use test2
> db.test2.insert({"name":"jiangxl","job":"it","age":"99"})
> db.test2.insert({"name":"wanger","job":"it","age":"99"})

MongoDB數據庫授權認證的實現

3.2.使用mytest登錄test庫驗證權限

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
1.登錄mytest用戶并連接到tets庫
[mongo@mongodb-1 ~]$ mongo -umytest -p123456 192.168.81.210:27017/test
 
2.查看所有表
> show tables
hash
test
 
3.查看是否有讀權限
> db.test.find()
{ "_id" : objectid("602c73b5d9d09b9b700c9eb2"), "name" : "xiaoming", "age" : 10 }
{ "_id" : objectid("602c73bdd9d09b9b700c9eb3"), "name" : "xiaohong", "age" : 10 }
{ "_id" : objectid("602c73c1d9d09b9b700c9eb4"), "name" : "xiaolan", "age" : 10 }
 
4.查看是否有寫入權限
> db.test.insert({"name":"xiaozhang","age":10})
 
5.查看是否寫入成功
> db.test.find()
{ "_id" : objectid("602c73b5d9d09b9b700c9eb2"), "name" : "xiaoming", "age" : 10 }
{ "_id" : objectid("602c73bdd9d09b9b700c9eb3"), "name" : "xiaohong", "age" : 10 }
{ "_id" : objectid("602c73c1d9d09b9b700c9eb4"), "name" : "xiaolan", "age" : 10 }
{ "_id" : objectid("602c74f949b9d3f400ed866b"), "name" : "xiaozhang", "age" : 10 }

可讀可寫

MongoDB數據庫授權認證的實現

3.3.使用mytest登錄test2庫驗證權限

由于普通用戶只能登錄test庫因此想要切換其他庫,只能是登陸test庫后使用use進行切換

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
1.登錄test庫
[mongo@mongodb-1 ~]$ mongo -umytest -p123456 192.168.81.210:27017/test
 
2.切換到tets2庫
> use test2
 
3.查看表
> show tables
test2
 
4.查看表中數據
> db.test2.find()
 
5.插入一條數據,查看是否插入成功
> db.test2.insert({"name":"xiaozi","job":"it","age":"99"})
writecommanderror({
    "ok" : 0,
    "errmsg" : "not authorized on test2 to execute command { insert: \"test2\", ordered: true, lsid: { id: uuid(\"6203f7df-d8f8-4880-aab3-4db712ae785f\") }, $db: \"test2\" }",
    "code" : 13,
    "codename" : "unauthorized"
})

可以看到只能讀取,不能插入

MongoDB數據庫授權認證的實現

到此這篇關于mongodb數據庫授權認證的實現的文章就介紹到這了,更多相關mongodb數據庫授權認證內容請搜索服務器之家以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持服務器之家!

原文鏈接:https://blog.csdn.net/weixin_44953658/article/details/122185708

延伸 · 閱讀

精彩推薦
  • MongoDBMongoDB中javascript腳本編程簡介和入門實例

    MongoDB中javascript腳本編程簡介和入門實例

    作為一個數據庫,MongoDB有一個很大的優勢——它使用js管理數據庫,所以也能夠使用js腳本進行復雜的管理——這種方法非常靈活 ...

    MongoDB教程網6982020-04-24
  • MongoDB遷移sqlserver數據到MongoDb的方法

    遷移sqlserver數據到MongoDb的方法

    這篇文章主要介紹了遷移sqlserver數據到MongoDb的方法,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下...

    聽楓xl9682021-01-03
  • MongoDBMongoDB憑什么躋身數據庫排行前五

    MongoDB憑什么躋身數據庫排行前五

    MongoDB以比去年同期超出65.96分的成績繼續雄踞榜單前五,這個增幅在全榜僅次于PostgreSQL的77.99,而其相對于4月份的6.10分的增長也是僅次于微軟SQL Server排名...

    孫浩峰3892020-05-22
  • MongoDBMongodb實現定時備份與恢復的方法教程

    Mongodb實現定時備份與恢復的方法教程

    這篇文章主要給大家介紹了Mongodb實現定時備份與恢復的方法教程,文中通過示例代碼介紹的非常詳細,對大家具有一定的參考學習價值,需要的朋友們下面...

    chenjsh364522020-05-13
  • MongoDBmongodb基本命令實例小結

    mongodb基本命令實例小結

    這篇文章主要介紹了mongodb基本命令,結合實例形式總結分析了MongoDB數據庫切換、查看、刪除、查詢等基本命令用法與操作注意事項,需要的朋友可以參考下...

    dawn-liu3652020-05-26
  • MongoDB分布式文檔存儲數據庫之MongoDB分片集群的問題

    分布式文檔存儲數據庫之MongoDB分片集群的問題

    這篇文章主要介紹了分布式文檔存儲數據庫之MongoDB分片集群的問題,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋...

    Linux-18743072020-12-20
  • MongoDBMongoDB 內存使用情況分析

    MongoDB 內存使用情況分析

    都說 MongoDB 是個內存大戶,但是怎么知道它到底用了多少內存呢...

    MongoDB教程網10002020-09-29
  • MongoDBMongoDB安裝圖文教程

    MongoDB安裝圖文教程

    這篇文章主要為大家詳細介紹了MongoDB安裝圖文教程,分為兩大部分為大家介紹下載MongoDB和安裝MongoDB的方法,感興趣的小伙伴們可以參考一下 ...

    Yangyi.He6132020-05-07
主站蜘蛛池模板: 国产中出视频 | 亚洲影视中文字幕 | 成人免费网站在线观看 | 成人午夜免费福利 | 精品国产91久久久久久浪潮蜜月 | 欧美www| 91精品国 | 日韩视频中文 | 国产99免费| 九九热精 | 久国产 | 成人在线视频播放 | 日产精品久久久一区二区开放时间 | 色av成人天堂桃色av | 免费三级大片 | 久久99久久99精品 | 欧美视频一区二区 | asian超清日本肉体pics | 国产精品18久久久久久久 | 精品一区二区久久久久久久网精 | videos高潮 | 最新午夜综合福利视频 | 久久99精品久久久久久秒播放器 | 久久久久久中文字幕 | 欧美一级视频免费看 | 久久免费综合视频 | 国产精品久久久免费 | 成人男女免费视频 | 国产自91精品一区二区 | 深夜免费福利视频 | 成人做爰高潮片免费视频美国 | 精品一区二区三区日本 | av在线免费观看网 | 米奇电影网 | 一级@片 | 天天躁狠狠躁夜躁2020挡不住 | 成人午夜激情视频 | 女人裸体让男人桶全过程 | 国产成年人视频 | 黄色的视频免费观看 | 毛片视频在线免费观看 |