docker中使用mongodb數(shù)據(jù)庫詳解(在局域網(wǎng)訪問)
前言
有了docker,基本上就告別了各種軟件、數(shù)據(jù)庫的安裝,直接從鏡像庫pull下來,爽,想想以前那真是一個(gè)遭罪啊。
這文章就來看一下如何跑mongo的docker鏡像,并且可以在局域網(wǎng)訪問,內(nèi)容相對(duì)簡單,也是記錄我的自學(xué)過程。
第一步
獲得mongo鏡像,命令如下,
# 拉取mongo鏡像 docker pull mongo # 查看本地庫mongo鏡像 docker images mongo
第二步
啟動(dòng)mongo鏡像,如下
# 啟動(dòng)mongo鏡像 docker run -itd -P --name mongo-server mongo bash # 查看mongo進(jìn)程 docker ps -a
第三步
進(jìn)入容器并啟動(dòng)mongo,如下
# 進(jìn)入mongo容器,其中‘mongo-server'是mongo容器別名 docker exec -it mongo-server bash # 啟動(dòng)mongo服務(wù) mongod & # 在容器中查看mongo進(jìn)程 ps -ef | grep mongo
啟動(dòng)以后會(huì)看到如下日志(最后幾行),
2017-06-13T07:25:56.318+0000 I FTDC [initandlisten] Initializing full-time diagnostic data capture with directory '/data/db/diagnostic.data' 2017-06-13T07:25:56.328+0000 I INDEX [initandlisten] build index on: admin.system.version properties: { v: 2, key: { version: 1 }, name: "incompatible_with_version_32", ns: "admin.system.version" } 2017-06-13T07:25:56.328+0000 I INDEX [initandlisten] building index using bulk method; build may temporarily use up to 500 megabytes of RAM 2017-06-13T07:25:56.329+0000 I INDEX [initandlisten] build index done. scanned 0 total records. 0 secs 2017-06-13T07:25:56.329+0000 I COMMAND [initandlisten] setting featureCompatibilityVersion to 3.4 2017-06-13T07:25:56.329+0000 I NETWORK [thread1] waiting for connections on port 27017
第四步
本地驗(yàn)證測(cè)試,輸入mongo啟動(dòng)mongo命令行客戶端,如下內(nèi)容
root@01ff7ed6377c:/# mongo MongoDB shell version v3.4.4 connecting to: mongodb://127.0.0.1:27017 2017-06-13T07:34:00.289+0000 I NETWORK [thread1] connection accepted from 127.0.0.1:55650 #2 (1 connection now open) 2017-06-13T07:34:00.290+0000 I NETWORK [conn2] received client metadata from 127.0.0.1:55650 conn2: { application: { name: "MongoDB Shell" }, driver: { name: "MongoDB Internal Client", version: "3.4.4" }, os: { type: "Linux", name: "PRETTY_NAME="Debian GNU/Linux 8 (jessie)"", architecture: "x86_64", version: "Kernel 3.10.0-327.28.3.el7.x86_64" } }
接著輸入測(cè)試命令,
> show dbs; admin 0.000GB local 0.000GB >
第五步
在局域網(wǎng)訪問docker中的mongo,由于啟動(dòng)的時(shí)候是使用的隨機(jī)端口映射,意思是宿主機(jī)產(chǎn)生一個(gè)隨機(jī)端口去映射mongo的27017端口,通過‘docker ps -a'
命令查看宿主機(jī)隨機(jī)端口,如下,
docker ps -a CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES 01ff7ed6377c mongo "docker-entrypoint.sh" 15 minutes ago Up 15 minutes 0.0.0.0:32773->27017/tcp mongo-server
如上,宿主機(jī)隨機(jī)端口為32773,通過配置robomongo客戶端連接mongo,如下,
結(jié)果正常。
如果要停止mongo可以使用如下命令,
# 登入mongo mongo # 選擇使用admin庫,在其他的庫不行 use admin # 關(guān)閉mongo db.shutdownServer()
通過‘ps -ef | grep momgo'
查看mongo進(jìn)程是否存在,如果不存在說明關(guān)閉成功。
總結(jié)
以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對(duì)給各位iOS開發(fā)者們能帶來一定的幫助,如果有疑問大家可以留言交流,謝謝大家對(duì)腳本之家的支持。
相關(guān)文章
Docker部署及使用壓測(cè)神器sysbench的方法
sysbench 是一個(gè)開源跨平臺(tái)的多線程性能測(cè)試工具,這篇文章主要介紹了Docker部署及使用壓測(cè)神器sysbench的相關(guān)知識(shí),需要的朋友可以參考下2022-08-08Docker 中快速安裝tensorflow環(huán)境的方法步驟
這篇文章主要介紹了Docker 中快速安裝tensorflow環(huán)境的方法步驟,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2018-10-10如何為Go程序創(chuàng)建一個(gè)最小的Docker Image詳解
這篇文章主要給大家介紹了關(guān)于如何為Go程序創(chuàng)建一個(gè)最小的Docker Image的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧。2017-11-11煮餃子論云原生docker與kubernetes之間的關(guān)系
這篇文章主要為大家用煮餃子論的道理來為大家講解一下云原生docker與kubernetes之間的關(guān)系,有需要的朋友可以借鑒參考下,希望能夠有所幫助2022-03-03Docker實(shí)現(xiàn)安裝ELK(單節(jié)點(diǎn))
這篇文章主要介紹了Docker實(shí)現(xiàn)安裝ELK(單節(jié)點(diǎn)),具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-08-08Linux下docker 容器退出bash的兩種實(shí)現(xiàn)方法
這篇文章主要介紹了Linux下docker 容器退出bash的兩種實(shí)現(xiàn)方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2020-11-11docker-compose.yml參數(shù)的用法(配置文件)
這篇文章主要介紹了docker-compose.yml參數(shù)的用法(配置文件),具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-11-11docker容器通信參數(shù)使用及l(fā)ink參數(shù)介紹
這篇文章主要介紹了docker容器通信參數(shù)使用及l(fā)ink參數(shù)介紹,link的原理就是在/etc/hosts里面添加了一個(gè)alias的名稱,本文通過案例分析給大家詳細(xì)講解,需要的朋友可以參考下2022-09-09