Single Node
| Server IP | Host Role |
|---|---|
| 192.168.10.4 | MongoDB Standalone |
Start Deployment
-
Download the MongoDB installation package
- Server Supports Internet Access
- Server Does Not Support Internet Access
wget https://pdpublic.mingdao.com/private-deployment/offline/common/mongodb-linux-x86_64-3.4.24.tgz# MongoDB installation package download link, upload to the deployment server after downloadinghttps://pdpublic.mingdao.com/private-deployment/offline/common/mongodb-linux-x86_64-3.4.24.tgz -
Extract to installation directory
tar -zxvf mongodb-linux-x86_64-3.4.24.tgzmv mongodb-linux-x86_64-3.4.24 /usr/local/mongodb -
Create a MongoDB user
useradd -M -s /sbin/nologin mongodb -
Create data and log directories and grant permissions
mkdir -p /data/mongodb/ /data/logs/mongodbchown -R mongodb:mongodb /usr/local/mongodb/ /data/mongodb/ /data/logs/mongodb -
Disable Transparent Huge Pages (THP)
MongoDB may experience performance degradation and memory fragmentation when THP is enabled. It is recommended to disable it via a systemd service before starting MongoDB.
cat > /etc/systemd/system/disable-thp.service <<\EOF[Unit]Description=Disable Transparent Huge Pages (THP)DefaultDependencies=noAfter=sysinit.target local-fs.targetBefore=mongodb.service[Service]Type=oneshotExecStart=/bin/sh -c 'echo never > /sys/kernel/mm/transparent_hugepage/enabled'ExecStart=/bin/sh -c 'echo never > /sys/kernel/mm/transparent_hugepage/defrag'[Install]WantedBy=basic.targetEOFsystemctl daemon-reloadsystemctl enable disable-thpsystemctl start disable-thp -
Configure systemd management file
cat > /etc/systemd/system/mongodb.service <<EOF[Unit]Description=MongoDBAfter=network-online.targetWants=network-online.target[Service]User=mongodbGroup=mongodbLimitNOFILE=1000000LimitNPROC=1000000LimitMEMLOCK=infinityExecStart=/usr/local/mongodb/bin/mongod --logpath /data/logs/mongodb/mongodb.log --dbpath /data/mongodb --auth --port 27017ExecStop=/usr/bin/kill \$MAINPIDRestart=on-failureRestartSec=5TimeoutStopSec=300[Install]WantedBy=multi-user.targetEOF -
Add to startup
# Since the user has not been created after installation, do not start the service with systemctl start mongodbsystemctl daemon-reloadsystemctl enable mongodb
Create Database Users
Operate on MongoDB Node01
-
Temporarily start a MongoDB service without connection authentication
su -c '/usr/local/mongodb/bin/mongod --fork --logpath /data/logs/mongodb/mongodb.log --dbpath /data/mongodb --noauth --port 27017' -s /bin/bash mongodb -
Create users
/usr/local/mongodb/bin/mongo <<<'use admindb.createUser({user:"root",pwd:"123456",roles:[{role:"root",db:"admin"}]})use MDLicensedb.createUser({user:"hap",pwd:"123456",roles:[{role:"readWrite",db:"MDLicense"}]})use ClientLicensedb.createUser({user:"hap",pwd:"123456",roles:[{role:"readWrite",db:"ClientLicense"}]})use commonbasedb.createUser({user:"hap",pwd:"123456",roles:[{role:"readWrite",db:"commonbase"}]})use MDAlertdb.createUser({user:"hap",pwd:"123456",roles:[{role:"readWrite",db:"MDAlert"}]})use mdapprolesdb.createUser({user:"hap",pwd:"123456",roles:[{role:"readWrite",db:"mdapproles"}]})use mdapprovedb.createUser({user:"hap",pwd:"123456",roles:[{role:"readWrite",db:"mdapprove"}]})use mdappsdb.createUser({user:"hap",pwd:"123456",roles:[{role:"readWrite",db:"mdapps"}]})use mdattachmentdb.createUser({user:"hap",pwd:"123456",roles:[{role:"readWrite",db:"mdattachment"}]})use mdcalendardb.createUser({user:"hap",pwd:"123456",roles:[{role:"readWrite",db:"mdcalendar"}]})use mdcategorydb.createUser({user:"hap",pwd:"123456",roles:[{role:"readWrite",db:"mdcategory"}]})use MDChatTopdb.createUser({user:"hap",pwd:"123456",roles:[{role:"readWrite",db:"MDChatTop"}]})use mdcheckdb.createUser({user:"hap",pwd:"123456",roles:[{role:"readWrite",db:"mdcheck"}]})use mddossierdb.createUser({user:"hap",pwd:"123456",roles:[{role:"readWrite",db:"mddossier"}]})use mdemaildb.createUser({user:"hap",pwd:"123456",roles:[{role:"readWrite",db:"mdemail"}]})use mdformdb.createUser({user:"hap",pwd:"123456",roles:[{role:"readWrite",db:"mdform"}]})use MDGroupdb.createUser({user:"hap",pwd:"123456",roles:[{role:"readWrite",db:"MDGroup"}]})use mdgroupsdb.createUser({user:"hap",pwd:"123456",roles:[{role:"readWrite",db:"mdgroups"}]})use MDHistorydb.createUser({user:"hap",pwd:"123456",roles:[{role:"readWrite",db:"MDHistory"}]})use mdIdentificationdb.createUser({user:"hap",pwd:"123456",roles:[{role:"readWrite",db:"mdIdentification"}]})use mdinboxdb.createUser({user:"hap",pwd:"123456",roles:[{role:"readWrite",db:"mdinbox"}]})use mdkcdb.createUser({user:"hap",pwd:"123456",roles:[{role:"readWrite",db:"mdkc"}]})use mdmapdb.createUser({user:"hap",pwd:"123456",roles:[{role:"readWrite",db:"mdmap"}]})use mdmobileaddressdb.createUser({user:"hap",pwd:"123456",roles:[{role:"readWrite",db:"mdmobileaddress"}]})use MDNotificationdb.createUser({user:"hap",pwd:"123456",roles:[{role:"readWrite",db:"MDNotification"}]})use mdpostdb.createUser({user:"hap",pwd:"123456",roles:[{role:"readWrite",db:"mdpost"}]})use mdreportdatadb.createUser({user:"hap",pwd:"123456",roles:[{role:"readWrite",db:"mdreportdata"}]})use mdrolesdb.createUser({user:"hap",pwd:"123456",roles:[{role:"readWrite",db:"mdroles"}]})use mdsearchdb.createUser({user:"hap",pwd:"123456",roles:[{role:"readWrite",db:"mdsearch"}]})use mdservicedatadb.createUser({user:"hap",pwd:"123456",roles:[{role:"readWrite",db:"mdservicedata"}]})use mdsmsdb.createUser({user:"hap",pwd:"123456",roles:[{role:"readWrite",db:"mdsms"}]})use MDSsodb.createUser({user:"hap",pwd:"123456",roles:[{role:"readWrite",db:"MDSso"}]})use mdtagdb.createUser({user:"hap",pwd:"123456",roles:[{role:"readWrite",db:"mdtag"}]})use mdtransferdb.createUser({user:"hap",pwd:"123456",roles:[{role:"readWrite",db:"mdtransfer"}]})use MDUserdb.createUser({user:"hap",pwd:"123456",roles:[{role:"readWrite",db:"MDUser"}]})use mdworkflowdb.createUser({user:"hap",pwd:"123456",roles:[{role:"readWrite",db:"mdworkflow"}]})use mdworksheetdb.createUser({user:"hap",pwd:"123456",roles:[{role:"readWrite",db:"mdworksheet"}]})use mdworkweixindb.createUser({user:"hap",pwd:"123456",roles:[{role:"readWrite",db:"mdworkweixin"}]})use mdwsrowsdb.createUser({user:"hap",pwd:"123456",roles:[{role:"readWrite",db:"mdwsrows"}]})use pushlogdb.createUser({user:"hap",pwd:"123456",roles:[{role:"readWrite",db:"pushlog"}]})use taskcenterdb.createUser({user:"hap",pwd:"123456",roles:[{role:"readWrite",db:"taskcenter"}]})use mdintegrationdb.createUser({user:"hap",pwd:"123456",roles:[{role:"readWrite",db:"mdintegration"}]})use mdactionlogdb.createUser({user:"hap",pwd:"123456",roles:[{role:"readWrite",db:"mdactionlog"}]})use mdworksheetlogdb.createUser({user:"hap",pwd:"123456",roles:[{role:"readWrite",db:"mdworksheetlog"}]})use mdworksheetsearchdb.createUser({user:"hap",pwd:"123456",roles:[{role:"readWrite",db:"mdworksheetsearch"}]})use mddatapipelinedb.createUser({user:"hap",pwd:"123456",roles:[{role:"readWrite",db:"mddatapipeline"}]})use mdwfplugindb.createUser({user:"hap",pwd:"123456",roles:[{role:"readWrite",db:"mdwfplugin"}]})use mdpaymentdb.createUser({user:"hap",pwd:"123456",roles:[{role:"readWrite",db:"mdpayment"}]})use mdwfaidb.createUser({user: "hap",pwd: "123456",roles: [{role: "readWrite",db: "mdwfai"}]})'- The root user's password for the MongoDB admin database specified in the command is
123456. It is essential to modify it to a strong password for actual deployment. - The password for the MongoDB business database user hap specified in the command is
123456. It is essential to modify it to a strong password for actual deployment. - If the password contains special characters, only
-or_are allowed. Characters like@ ! # &are prohibited to avoid compatibility issues.
- The root user's password for the MongoDB admin database specified in the command is
-
Shut down the temporarily started MongoDB
kill $(pgrep -f 'mongod')
Start MongoDB
systemctl start mongodb