MongoDB-安裝&啟動

来源:http://www.cnblogs.com/cyhe/archive/2016/04/23/5425253.html
-Advertisement-
Play Games

MongoDB安裝 使用的版本為3.0,虛擬機操作系統為rhel-server-7.0-x86_641. 將mongodb-linux-x86_64-rhel70-3.0.11.tgz上傳並解壓到 /usr/local/mongodb 目錄下2. 設置環境變數# vi /etc/profile添加e ...


MongoDB安裝


 使用的版本為3.0,虛擬機操作系統為rhel-server-7.0-x86_64
1. 將mongodb-linux-x86_64-rhel70-3.0.11.tgz上傳並解壓到 /usr/local/mongodb 目錄下
2. 設置環境變數
# vi /etc/profile
添加export PATH=$PATH:/usr/local/mongodb/bin
# source /etc/profile
# mongo -version
MongoDB shell version: 3.0.11

Ok接下測試一下

首先新建一個目錄,MongoDB相關的數據文件都在放在此目錄下
# mkdir /data/mongodb

MongoDB啟動


 

啟動MongoDB時,可以在命令行中添加參數,也能把參數寫在配置文件中
1. 參數寫在配置文件中
參數種類有很多,有關於日誌的,資料庫的,網路的,集群的等...
詳細的參數以及說明詳見官網:https://docs.mongodb.org/manual/reference/configuration-options/

在/data/mongodb目錄下新建一個配置文件 mongo.conf
註意:縮進內容不支持tab只能用空格...
配置文件的內容為:
systemLog:
   destination: file
   path: "/data/mongod.log"
   logAppend: true
storage:
   dbPath: /data/mongodb
   journal:
      enabled: true
   directoryPerDB: true
processManagement:
   fork: true
net:
   bindIp: 127.0.0.1
   port: 27017

啟動mongod服務
# mongod --config /data/mongodb/mongo.conf
about to fork child process, waiting until server is ready for connections.
forked process: 3037
child process started successfully, parent exiting

服務啟動成功
# ps -aux|grep mongod
root       3037  1.8  1.6 490120 46544 ?        Sl   10:28   0:00 mongod --config /data/mongodb/mongo.conf
root       3049  0.0  0.0 112640   980 pts/0    S+   10:28   0:00 grep --color=auto mongod

連接到 mongo shell
# mongo --port 27017
MongoDB shell version: 3.0.11
connecting to: 127.0.0.1:27017/test
>

Ok啟動完畢

2. 命令行指定參數
命令行啟動就更簡單了直接輸入命令回車即可
mongod --port=27017 --dbpath=/data/mongodb --logpath=/data/mongod.log --logappend --directoryperdb --fork

關於配置文件和命令行選項參數,我覺得可以把各個伺服器共用的配置寫在文件里,針對性的配置,放在命令行中,比較好統一管理

簡單說明一下使用到的參數:
--port:埠號
--dbpath:資料庫文件存放路徑
--logpath:日誌存放位置
--logappend:日誌追加到文件末尾
--directoryperdb:true 使用一個單獨的目錄為每個資料庫來存儲數據
--fork:後臺運行
journal:啟用日誌記錄,當伺服器斷電,意外重啟等可以防止數據丟失


此外,現在的機器基本是多CPU,多記憶體塊,如果我們直接使用mongod 命令啟用會得到一個警告
WARNING: You are running on a NUMA machine.

只需要在原啟動命令前添加  numactl –interleave=all  即可,比如上面的啟動命令
# cd /usr/local/mongodb/bin/
numactl –interleave=all ./mongod --port=27017 --dbpath=/data/mongodb --logpath=/data/mongod.log --logappend --directoryperdb --fork

至於為什麼這樣啟動,我從網上找了片文章,不知道能不能徹底說明問題,可以瞭解一下
https://www.ttlsa.com/mongodb/mongodb-numa/

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • Redis官網對 info 已經講解的比較清楚的,參考文檔 。可以看到,info的輸出結果是分幾塊的,有Servers、Clients、Memory等等,通過info後面接這些參數,可以指定輸出某一塊數據。 Redis 2.4.10,並沒有分塊輸出,而且也無法按上面說的加選項控制輸出某一塊,後來升級 ...
  • 1、複製概述1.1、複製解決的問題數據複製技術有以下一些特點:(1) 數據分佈(2) 負載平衡(load balancing)(3) 備份(4) 高可用性(high availability)和容錯1.2、複製如何工作從高層來看,複製分成三步:(1) master將改變記錄到二進位日誌(binary ...
  • 點擊查看Oracle函數大全線上版 SQL中的單記錄函數1.ASCII返回與指定的字元對應的十進位數;SQL> select ascii('A') A,ascii('a') a,ascii('0') zero,ascii(' ') space from dual; A A ZERO SPACE 65 ...
  • 要理解join語句,首先得明白笛卡爾乘積(即集合的乘運算),其定義如下: 笛卡爾(Descartes)乘積又叫直積。假設集合A={a,b},集合B={0,1,2},則兩個集合的笛卡爾積為{(a,0),(a,1),(a,2),(b,0),(b,1), (b,2)}。 在SQL的join聯結操作中,其實 ...
  • 條件有限,只在一臺機器上模擬部署一下,相關參數就不寫在配置文件里了,直接使用命令指定參數這裡我模擬三個伺服器分別為 serverA,serverB,serverC我是通過修改/etc/hosts 將他們d綁定到 127.0.0.1# cat /etc/hosts127.0.0.1 localhost ...
  • 從表中刪除某條記錄: delete from table_name where xx=xxxx; ...
  • 來源於工作中的一個實際問題, 這裡是組合列數據不均勻導致查詢無法預估數據行數,從而導致無法選擇合理的執行計劃導致性能低下的情況 我這裡把問題簡單化,主要是為了說明問題 進行如下查詢,就是查詢那條所謂的特殊數據 發現執行計劃如下:走的是全表掃描,IO代價也不小, 這種情況下,明明只有一條數據,卻要走全 ...
  • 轉自CSDN shl7765856的專欄:http://blog.csdn.net/shl7765856/article/details/7411987 目錄: 1.MySql連接配置 2.Sql Server連接配置 3.Oracle連接配置 4.DB2連接配置 5.sybase連接配置 6.in ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...