Ubuntu安装MongoDB

一、下载安装

首先,更新软件包列表以获取最新版本的存储库列表:

sudo apt update

2.接着安装MongoDB包本身:

sudo apt install -y mongodb

×加-y是为了在后面安装过程中跳过要输入一次Y的步骤。

该命令安装了几个包含最新稳定版本的MongoDB的软件包,以及MongoDB服务器的有用管理工具。 数据库服务器在安装后自动启动。

二、检查是否成功

首先检查服务的状态:

sudo systemctl status mongodb

如果输出下面类似的内容,说明安装成功了

● mongodb.service - An object/document-oriented database
   Loaded: loaded (/lib/systemd/system/mongodb.service; enabled; vendor preset: enabled)
   Active: active (running) since Sat 2018-11-03 14:21:52 CST; 2min 38s ago
     Docs: man:mongod(1)
 Main PID: 20731 (mongod)
    Tasks: 23 (limit: 4915)
   CGroup: /system.slice/mongodb.service
           └─20731 /usr/bin/mongod --unixSocketPrefix=/run/mongodb --config /etc/mongodb.conf

可以通过实际连接到数据库服务器并执行诊断命令来进一步验证:

mongo --eval 'db.runCommand({ connectionStatus: 1 })'

这将输出当前的数据库版本,服务器地址和端口以及状态命令的输出:

MongoDB shell version v3.6.3
connecting to: mongodb://127.0.0.1:27017
MongoDB server version: 3.6.3
{
	"authInfo" : {
		"authenticatedUsers" : [ ],
		"authenticatedUserRoles" : [ ]
	},
	"ok" : 1
}

响应中的ok字段的值为1表示服务器工作正常。

 三、管理MongoDB

默认情况下,MongoDB被配置为自动启动服务器。 如果希望禁用自动启动:

sudo systemctl disable mongodb

再次启用它同样简单:

sudo systemctl enable mongodb

要验证服务的状态:

sudo systemctl status mongodb

停止服务器:

sudo systemctl stop mongodb

启动服务器:

sudo systemctl start mongodb

重新启动服务器:

sudo systemctl restart mongodb

 四、防火墙设置(根据自己情况设置)

假设已经遵循了最初的服务器设置教程说明来启用服务器上的防火墙,MongoDB服务器将无法从Internet访问。

如果打算只在本地使用运行在同一台服务器上的应用程序的MongoDB服务器,则这是建议和安全的设置。 但是,如果希望能够通过Internet连接到MongoDB服务器,则必须允许ufw的传入连接。要允许从任何地方访问其默认端口27017上的MongoDB,可以使用sudo ufw allow 27017 。 但是,通过默认安装启用对MongoDB服务器的互联网访问,任何人都可以不受限制地访问数据库服务器及其数据。

在大多数情况下,MongoDB只能从特定的可信位置访问,例如托管应用程序的另一台服务器。 要完成此任务,可以允许访问MongoDB的默认端口,同时指定另一个明确允许连接的服务器的IP地址:

sudo ufw allow from your_other_server_ip/32 to any port 27017

可以使用ufw验证防火墙设置中的更改:

sudo ufw status

将看到输出中允许的端口27017流量:

Status: active

To                         Action      From
--                         ------      ----
OpenSSH                    ALLOW       Anywhere
27017                      ALLOW       Anywhere
OpenSSH (v6)               ALLOW       Anywhere (v6)
27017 (v6)                 ALLOW       Anywhere (v6)

如果只允许某个IP地址连接到MongoDB服务器,则允许位置的IP地址将在输出中列出而不是Anywhere 。

可以找到更多高级防火墙设置来限制UFW Essentials中的服务访问:通用防火墙规则和命令 。

即使端口处于打开状态,MongoDB当前也只能监听本地地址127.0.0.1 。 要允许远程连接,请将服务器的可公开路由的IP地址添加到mongod.conf文件中。

在您的编辑器中打开MongoDB配置文件:

sudo gedit /etc/mongodb.conf

将您的服务器的IP地址添加到bindIP值:

...
logappend=true

bind_ip = 127.0.0.1,your_server_ip
#port = 27017
...

务必在现有IP地址和添加的地址之间放置逗号。

保存文件,退出编辑器,然后重新启动MongoDB:

sudo systemctl restart mongodb

MongoDB现在正在监听远程连接,但任何人都可以访问它。 后面可以通过添加管理用户并进一步锁定。

原文地址:https://www.cnblogs.com/darklights/p/9900794.html