Ubuntu下node+mongodb环境搭建完全实践

之前给腾讯云重新装了系统,按照网上的教程搭建node+mongodb环境时,遇到了一些问题,在此整理一份完整的配置过程。

本文包含的内容:

  1. Ubuntu下高版本node环境的搭建
  2. Ubuntu下mongodb环境的搭建
  3. Ubuntu下mongodb的安全配置

使用的系统是Ubuntu Server 16.04.1 LTS 64位

1. Ubuntu下高版本node环境的搭建

curl -sL https://deb.nodesource.com/setup_6.x | sudo -E bash -

这里的数字6可以更改为其他数字,比如改为8,就能指定安装的node为8版本

sudo apt-get install -y nodejs

输入这一条命令安装node(默认是安装最新稳定版)

node -v
npm  -v

检查安装的node及npm版本

至此node的环境就算安装完成了。

如果想要修改本机的node版本的话,重复上面的流程,替换数字,就能换到对应的node版本。

若想要在ubuntu上运行js代码,可以执行下面的操作:

sudo mkdir -p /code/  
sudo chmod 755 /code/* 

将代码放入根目录的code目录下,再执行相应的操作即可(如:npm startnode test.js)。


2. Ubuntu下mongodb环境的搭建

sudo apt-key adv --keyserver hkp://keyserver.ubuntu.com:80 --recv EA312927

添加mongodb签名到APT

echo "deb http://repo.mongodb.org/apt/ubuntu xenial/mongodb-org/3.2 multiverse" | sudo tee /etc/apt/sources.list.d/mongodb-org-3.2.list

创建/etc/apt/sources.list.d/mongodb-org-3.2.list文件并写入命令

sudo apt-get update

更新软件源列表

安装完成后,需要进行一系列的配置

sudo mkdir -p /data/db    
sudo chmod 755 /data/* 

创建数据存储目录并赋予目录权限

启动mongodb的命令是 sudo mongod而想要将mongodb注册为service,还要进行配置。

mongo service的用法如下:

sudo service mongodb start
sudo service mongodb stop
sudo service mongodb restart

若目前直接输入以上service命令运行,会报错:Failed to start mongod.service: Unit mongod.service not found.

要使service能正常启动,需要执行以下操作。

sudo nano /etc/systemd/system/mongodb.service

创建并编辑mongodb.service的内容

[Unit]
Description=High-performance, schema-free document-oriented database
After=network.target

[Service]
User=mongodb
ExecStart=/usr/bin/mongod --quiet --config /etc/mongod.conf

[Install]
WantedBy=multi-user.target

复制以上内容,粘贴到编辑界面内(我使用的xshell连接腾讯云,用shift+insert粘贴),复制完成后保存并退出。

sudo systemctl enable mongodb

启用mongodb的service

完成了以上操作之后,service命令就能正常使用了。

sudo service mongodb start

启动mongodb的service进程,之后可以键入mongo进入mongodb,默认连接mongodb的test数据库。


3. Ubuntu下mongodb的安全配置

本来执行了上面两步,环境就已经搭建好了,也可以开始使用了,但mongodb默认不开启用户验证。这意味着开放外网访问后,任何人都可以通过mongo客户端访问你的数据库,做任何操作,如drop database ,这无疑是非常不安全的,因此为了数据的安全,我们应当进行安全配置,也就是加入用户验证。

mongo

首先连接到mongodb

use admin

连接到admin数据库

db.createUser({user:"admin",pwd:"管理员密码",roles:[{role:"root",db:"admin"}]})

创建管理员用户

要注意的是,创建哪个数据库的用户,需要切换到相应数据库,比如为student数据库创建一个用户,首先需要

use student
db.createUser({user:"名字",pwd:"密码",roles:[{role:"dbOwner",db:"你的应用数据库"}]})

创建普通用户

db的role选什么可以参考mongodb的官方文档,这里使用dbOwner,能够对单个数据库做任何操作,方便开发。

创建成功后按ctrl+c退出mongo客户端,去修改mongodb的配置

sudo vi /etc/mongod.conf

修改mongod启动时的配置文件

vi的操作就不赘述了,需要做的事情有:

  1. 注释bindIp: 127.0.0.1,这样能够远程访问你的数据库,而不是只能本机访问。
  2. 取消security:的注释,并加上authorization: enabled
  3. 保存退出。
sudo service mongodb restart

重启mongodb

至此mongodb的安全配置也完成了。


以上是我整理的Ubuntu下node+mongodb环境搭建,希望能帮到大家。

参考:

  1. 在乌班图 Ubuntu 16.04 上安装 Node.js 6.X 和 npm
  2. Ubuntu 安装 Mongodb
  3. MongoDB (3.2) doesn't start on Lubuntu 16.04 LTS as a service

附:

echo never > /sys/kernel/mm/transparent_hugepage/enabled  
echo never> /sys/kernel/mm/transparent_hugepage/defrag

关闭transparent_hugepage

你可能感兴趣的:(Ubuntu下node+mongodb环境搭建完全实践)