91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

mongodb中怎么開啟set認證

發布時間:2021-07-19 11:49:28 來源:億速云 閱讀:213 作者:Leah 欄目:MongoDB數據庫

本篇文章給大家分享的是有關mongodb中怎么開啟set認證,小編覺得挺實用的,因此分享給大家學習,希望大家閱讀完這篇文章后可以有所收獲,話不多說,跟著小編一起來看看吧。

環境:

系統均為Centos 7,

mongodb-linux-x86_64-rhel70-3.4.5.tgz

節點:

node0:Primary

node1:Secondary

node2:Secondary

node3:Arbiter

node0:

解壓mongodb包到 /usr/local/mongodb

在/usr/local/mongodb下創建 etc、log目錄

把/usr/local/mongodb/bin  添加到/etc/profile系統環境變量

創建放在數據目錄 /var/lib/mongodb/data

創建服務啟動腳本

vi /usr/lib/systemd/system/mongodb.service 添加如下內容

[Unit]

Description=Mongodb Monitoring and Control Daemon

After=Network.target

#Network must be start before this service

[Service]

Type=forking

ExecStart=/usr/local/mongodb/bin/mongod -f /usr/local/mongodb/etc/mongodb.conf

ExecStop=/usr/local/mongodb/bin/mongod --shutdown

KillMode=process

Restart=on-failure

#Restart=always

# always mean restart service even this service stop by yourself,using pkill or kill to stop a service.

RestartSec=15s

[Install]

WantedBy=multi-user.target

########

設置開機啟動

systemctl enable mongodb

其他3個節點跟上面操作一樣

node0:

生成SSL KEY文件

openssl rand -base64 741 > /usr/local/mongodb/mongodb.key

把 /usr/local/mongodb/mongodb.key 文件復制到其他3個節點

配置mongodb

node0:

cat /usr/local/mongodb/etc/mongodb.conf

dbpath=/var/lib/mongodb/data
logpath=/usr/local/mongodb/log/mongodb.log 
pidfilepath=/usr/local/mongodb/mongodb.pid
directoryperdb=true
logappend=true
#replSet=mggroup1
bind_ip=0.0.0.0
port=27017
oplogSize=10000
fork=true
#noprealloc=true
#keyFile=/usr/local/mongodb/mongodb.key
maxConns=10000

如果需要在直接執行 mongod -f config_file_path,把fork=true注釋

創建用戶

啟動mongodb 

systemctl start mongodb

打開mongodb shell

mongo --port 27017

use admin
db.createUser( {
 user: "mgpai",
 pwd: "passwd",
 roles: [ { role: "userAdminAnyDatabase", db: "admin" } ]
 });
db.createUser( {
 user: "mgroot",
 pwd: "passwd",
 roles: [ { role: "root", db: "admin" } ]
 });
 
 
# 退出
quit()
 
# 查看用戶
db.system.users.find()

# 刪除用戶
db.system.users.remove({user:'username'})

停止node0 mongodb服務

systemctl stop mongodb

把/usr/local/mongodb/etc/mongodb.conf配置文件中下面兩注釋取消

#replSet=mggroup1

#keyFile=/usr/local/mongodb/mongodb.key

node0重新開啟mongodb服務

systemctl start mongodb

其他3個節點配置文件: cat /usr/local/mongodb/etc/mongodb.conf

dbpath=/var/lib/mongodb/data
logpath=/usr/local/mongodb/log/mongodb.log 
pidfilepath=/usr/local/mongodb/mongodb.pid
directoryperdb=true
logappend=true
replSet=mggroup1
bind_ip=0.0.0.0
port=27017
oplogSize=10000
fork=true
#noprealloc=true
keyFile=/usr/local/mongodb/mongodb.key
maxConns=10000

其他3個節點都開啟mongodb服務

replica set配置

node0: 登錄mongodb 

mongo 127.0.0.1:27017 /admin -u mgroot -p

輸入密碼

cfg = {_id: 'mggroup1', members: [
    {_id:0, host:'192.168.1.13:1707', priority:2},
    {_id:1, host:'192.168.1.16:1707', priority:1},
    {_id:2, host:'192.168.1.17:1707', priority:1},
    {_id:3, host:'192.168.1.19:1707', arbiterOnly:true},
    ]
}

# cfg變量可取其它名,不與mongodb的主要關鍵字沖突就行

# 初始化,只能執行一次,若想取消,把dbpath下的文件刪除,重啟服務
rs.initiate(cfg) 


# 查看replica set狀態
rs.status()
#myState本節點狀態,1表示 Primary, 2 表示 Secondary, 7 表示 Arbiter

附:讓mongodb set 的secondary支持讀操作

對于replica set 中的secondary 節點默認是不可讀的。在寫多讀少的應用中,使用Replica Sets來實現讀寫分離。通過在連接時指定或者在主庫指定slaveOk,由Secondary來分擔讀的壓力,Primary只承擔寫操作。

如果通過shell訪問mongo,要在secondary進行查詢。會出現如下錯誤:

p_w_picpathSet:SECONDARY> db.fs.files.find()

error: { "$err" : "not master and slaveOk=false", "code" : 13435 }

有兩種方法實現從機的查詢:

第一種方法:db.getMongo().setSlaveOk();

第二種方法:rs.slaveOk();

但是這種方式有一個缺點就是,下次再通過mongo進入實例的時候,查詢仍然會報錯,為此可以通過下列方式

vi ~/.mongorc.js

增加一行rs.slaveOk();

這樣的話以后每次通過mongo命令進入都可以查詢了

如果是通過java訪問secondary的話則會報下面的異常

com.mongodb.MongoException: not talking to master and retries used up

解決的辦法很多。

第一種方法:在java代碼中調用dbFactory.getDb().slaveOk();

第二種方法:在java代碼中調用

dbFactory.getDb().setReadPreference(ReadPreference.secondaryPreferred());//在復制集中優先讀secondary,如果secondary訪問不了的時候就從master中讀

dbFactory.getDb().setReadPreference(ReadPreference.secondary());//只從secondary中讀,如果secondary訪問不了的時候就不能進行查詢

第三種方法:在配置mongo的時候增加slave-ok="true"也支持直接從secondary中讀

<mongo:mongo id="mongo" host="${mongodb.host}" port="${mongodb.port}">

        <mongo:options slave-ok="true"/> 

</mongo:mongo>

以上就是mongodb中怎么開啟set認證,小編相信有部分知識點可能是我們日常工作會見到或用到的。希望你能通過這篇文章學到更多知識。更多詳情敬請關注億速云行業資訊頻道。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

互助| 大厂| 阿拉善左旗| 正安县| 龙州县| 东乡族自治县| 石景山区| 绿春县| 京山县| 尼勒克县| 偃师市| 资阳市| 永川市| 漾濞| 滨海县| 武隆县| 绥江县| 正定县| 尚志市| 石城县| 长汀县| 滕州市| 阜宁县| 阳城县| 定南县| 武乡县| 滦南县| 高尔夫| 哈巴河县| 确山县| 新乡县| 友谊县| 图木舒克市| 彩票| 贵阳市| 永州市| 彰武县| 中山市| 涟水县| 喜德县| 军事|