在Ubuntu上開啟MongoDB的IP Security

来源:https://www.cnblogs.com/Tsoagta/archive/2018/02/25/8469746.html
-Advertisement-
Play Games

本文翻譯之MongoDB官網博客,原地址:https://www.mongodb.com/blog/post/enabling-ip-security-for-mongodb-36-on-ubuntu MongoDB3.6的預設配置會拒絕未授權的鏈接對公共網路的訪問,從而保護數據收到外部威脅。Mon ...


本文翻譯之MongoDB官網博客,原地址:https://www.mongodb.com/blog/post/enabling-ip-security-for-mongodb-36-on-ubuntu

MongoDB3.6的預設配置會拒絕未授權的鏈接對公共網路的訪問,從而保護數據收到外部威脅。MongoDB只會監聽本地鏈接,除非添加規則允許監聽其他地址。

 

本教程會簡明的展示如何允許外部IP地址連接MongoDB節點,並保證聯網伺服器可以連接到你的資料庫。通過本教程,你會發現配置MongoDB監聽具體的網路埠是很容易的一件事情。

 

看本教程前,你需要:

l  安裝MongoDB3.6

l  伺服器上有多個網路介面(本例會使用AWS EC2實例)

l  瞭解IP網路的基本知識,會配置私有IP

 

我啟動了安裝有 Ubuntu 16.04 LTS的一臺AWS EC2的實例,並且安裝了MongoDB3.6

我想允許我的部分VPC IP地址連接到我們的MongoDB資料庫。通過這種方式,可以保證只有我們的指定IP以及本機才能連接到資料庫,而其他陌生地址禁止訪問資料庫。

 

首先啟動VPC公共子網中的Ubuntu實例。

根據MongoDB官網文檔安裝mongodb3.6,通過以下命令可以查看進程占用了那個網路埠:

ubuntu@ip-172-16-0-211:~$ sudo netstat -plant | egrep mongod

tcp        0      0 127.0.0.1:27017         0.0.0.0:*               LISTEN      2549/mongod

命令結果輸出顯示用戶只允許通過本機的27017埠進行訪問,如果想其他系統訪問資料庫,就需要進行IP綁定。運行ifconfig命令

ubuntu@ip-172-16-0-211:~$ ifconfig
eth0      Link encap:Ethernet  HWaddr 0e:5e:76:83:49:3e
          inet addr:172.16.0.211  Bcast:172.16.0.255  Mask:255.255.255.0
          inet6 addr: fe80::c5e:76ff:fe83:493e/64 Scope:Link
          UP BROADCAST RUNNING MULTICAST  MTU:9001  Metric:1
          RX packets:65521 errors:0 dropped:0 overruns:0 frame:0
          TX packets:7358 errors:0 dropped:0 overruns:0 carrier:0
          collisions:0 txqueuelen:1000
          RX bytes:94354063 (94.3 MB)  TX bytes:611646 (611.6 KB)

現在我們知道了我們想要監聽的網路地址,打開/etc/mongodb.conf文件,進行編輯,文件修改後如下:

# network interfaces
net:
  port: 27017
  bindIp: 127.0.0.1,172.16.0.211

現在文件中就添加了一個IP地址172.16.0.211, 重啟mongod服務。

ubuntu@ip-172-16-0-211:~$ sudo service mongod stop
ubuntu@ip-172-16-0-211:~$ sudo service mongod start
ubuntu@ip-172-16-0-211:~$ sudo netstat -plnt | egrep mongod
tcp        0      0 172.16.0.211:27017      0.0.0.0:*               LISTEN      2892/mongod
tcp        0      0 127.0.0.1:27017         0.0.0.0:*               LISTEN      2892/mongod

可以看到現在除了本機,資料庫還可以接受指定的IP的請求。

通過本機連接:

ubuntu@ip-172-16-0-211:~$ mongo localhost
MongoDB shell version v3.6.0-rc2
connecting to: mongodb://127.0.0.1:27017/localhost

通過指定IP連接

ubuntu@ip-172-16-0-211:~$ mongo 172.16.0.211
MongoDB shell version v3.6.0-rc2
connecting to: mongodb://172.16.0.211:27017/test

預設的本機配置是有很多好處的,但是現在就需要明確指定那些網路可以連接資料庫,防止不信任的網路連接到系統。保證MongoDB系統不受遠程攻擊是非常重要的,確保只有在安全清單上的IP才能連接到系統。

你就知道瞭如何為系統配置其他IP地址以訪問資料庫,現在就可以為你的複製集進行配置了。不要忘記做備份、監控。如果你不想在這些工作上消耗太多精力,可以瞭解一下我們的資料庫即服務:MongoDB Atlas。


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

-Advertisement-
Play Games
更多相關文章
  • 轉自:http://www.cnblogs.com/TankXiao/p/3164995.html 整理了一些VS的快捷鍵 格式化整個文檔:(Ctrl + K, Ctrl + D)智能感知:(Ctrl + J)查看函數參數: (Ctrl+K, Ctrl+P)插入代碼段:(Ctrl+K, Ctrl+S ...
  • 認識線程 因為新啟動的線程里會休息一下,所以肯定是主線程的方法先執行, 如果想讓新啟動的線程執行完再去執行主線,也就是讓主線程等待,可以用 join 有時候覺得新啟動的線程有點不聽話,乾脆幹掉吧,讓它活一會已經夠意思了,可以用Abort,但是這個容易出問題,不建議使用。 線程是有前後之分的,預設顯示 ...
  • 1 2 //WINForm窗體中切換前後臺線程執行任務: 3 protected void RunOnUI(Action action) 4 { 5 Invoke(action); 6 } 7 8 protected void RunOnBg(Action action) ... ...
  • Linux網路配置 RPM命令 samba服務 Linux目錄結構 ...
  • SPI知識總結 一、定義 SPI(Serial Peripheral Interface--串列外設介面)匯流排系統是一種同步串列外設介面,它可以使MCU與各種外圍設備以串列方式進行通信以交換信息。 優點:支持全雙工通信、通信簡單、數據傳輸速率塊; 缺點:沒有指定的流控制,沒有應答機制確認是否接收到數 ...
  • 第一次安裝CentOS後,man命令無法使用,查了一下,發現沒有安裝man命令程式。嘗試安裝man yum install man 結果如下: Loaded plugins: fastestmirror Setting up Install Process Could not retrieve mi ...
  • CentOS修改IP地址 # ifconfig eth0 192.168.1.80 這樣就把IP地址修改為192.168.1.80(如果發現上不了網了,那麼你可能需要把網關和DNS也改一下,後面會提到),但是當你重新啟動系統或網卡之後,還是會變回原來的地址,這種修改方式只適用於需要臨時做IP修改。要 ...
  • 安裝GNOMEyum groupinstall GNOME Desktop 安裝VNC-Serversudo yum install tigervnc-server 拷貝VNC-Server配置文件到systemd系統下cp /lib/systemd/system/[email protected] ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...