linux安装mongoDB与NodeJs远程连接

6,813 阅读6分钟

一、下载linux版本mongoDB

版本说明

development release ---->开发版

current release ---->当前稳定版

previous release ---->旧版本

系统说明

Ubuntu ----> 优般图
Linux legacy ----> 通用版
window ----> 不解释
RHEL Linux ----> 红帽
Amazon Linux ----> 亚马逊
Debian Linux ----> Debian
SUSE Linux ----> SUSE
  • 我linux系统安装的是centOS 7,属于红帽旗下,所以我选择的RHEL 7.2 Linux的mongoDB,贴个图,我选择的各个版本

  • 安装 这次安装使用tgz包

1,安装wget
[root@izbp1b498epn4trb75oykez ~]# yum -y install wget
2,使用wget下载tgz包,我当前目录/usr/local/
[root@izbp1b498epn4trb75oykez local]# wget https://fastdl.mongodb.org/linux/mongodb-linux-x86_64-rhel70-4.0.9.tgz
3,新建mongoDB文件夹,将tgz文件解压至mongoDB文件夹下
[root@izbp1b498epn4trb75oykez local]# mkdir mongoDB
[root@izbp1b498epn4trb75oykez local]# tar -zxvf mongodb-linux-x86_64-rhel70-4.0.9.tgz -C /usr/local/mongoDB
4,进入mongoDB目录,查看目录文件,发现还有一个mongodb-linux-x86_64-rhel70-4.0.9目录,这个目录内才是mongoDB的文件,我们将这个目录内的文件移动到mongoDB目录下
[root@izbp1b498epn4trb75oykez local]# cd mongoDB/
[root@izbp1b498epn4trb75oykez mongoDB]# ls
mongodb-linux-s390x-rhel72-4.0.9
[root@izbp1b498epn4trb75oykez mongoDB]# cd mongodb-linux-x86_64-rhel70-4.0.9
[root@izbp1b498epn4trb75oykez mongodb-linux-x86_64-rhel70-4.0.9]# ls
bin  LICENSE-Community.txt  MPL-2  README  THIRD-PARTY-NOTICES
[root@izbp1b498epn4trb75oykez mongodb-linux-x86_64-rhel70-4.0.9]# mv * ../
5,删除已无用的mongodb-linux-x86_64-rhel70-4.0.9文件夹,(没有强迫症可不删)
[root@izbp1b498epn4trb75oykez mongoDB]# rm -rf mongodb-linux-x86_64-rhel70-4.0.9

二、配置启动

  • 在mongoDB根目录下创建data目录及其子目录db,以及日志目录logs以及其日志文件mongoLogs.log,和配置文件mongodb.conf,命令如下
[root@izbp1b498epn4trb75oykez mongoDB]# mkdir data
[root@izbp1b498epn4trb75oykez mongoDB]# mkdir data/db
[root@izbp1b498epn4trb75oykez mongoDB]# mkdir logs
[root@izbp1b498epn4trb75oykez mongoDB]# touch logs/mongoLogs.log
[root@izbp1b498epn4trb75oykez mongoDB]# touch mongodb.conf
  • 编辑配置文件mongodb.conf,命令如下
[root@izbp1b498epn4trb75oykez mongoDB]# vi mongodb.conf 
  • 打开文件后,英文状态下按键盘i键进入文件编辑状态,文件内容如下
#端口号 默认27017
port=27017

#数据目录
dbpath = /usr/local/mongoDB/data/db

#日志文件
logpath = /usr/local/mongoDB/logs/mongoLogs.log

#设置后台运行
fork = true

#日志输出方式
logappend = true
  • 编辑好之后按键盘ESC退出编辑状态,接着按shift+:键,然后输入wq,按回车保存退出
  • 以配置文件启动mongodb,命令如下
[root@izbp1b498epn4trb75oykez bin]# ./mongod --config /usr/local/mongoDB/mongodb.conf
about to fork child process, waiting until server is ready for connections.
forked process: 6685
child process started successfully, parent exiting
./mongo连接测试库
[root@izbp1b498epn4trb75oykez bin]# ./mongo
  • 启动成功,./mongo连接测试库,连接成功输入exit退出

三、配置账户,授权登录

  • mongodb我们已经安装完成,也成功启动连接上了测试库,但此时我们./mongo启动的时候是默认不需要授权登录的,这样并不安全,所以我们需要创建管理员,之后启动及操作都需要授权登录才可以进行。

  • 创建admin数据库,创建用户,设置账号,密码,权限

> use admin
switched to db admin
> db.createUser({user:"root",pwd:"123456",roles:["root"]})
Successfully added user: { "user" : "root", "roles" : [ "root" ] }

Tip: 如果你跟着我的步骤执行,结果密码也误设置成123456,那么这里提供两个修改密码的方法:

  1. db.changeUserPassword("usertest","changepass") usertest用户, changepass新密码
  2. db.updateUser("usertest",{pwd:"changepass1"})
  • 使用账号密码登录后,结束mongodb程序
> use admin
switched to db admin
> db.auth('root','123456');
1
> db.shutdownServer();
Wed Nov 14 06:07:33 DBClientCursor::init call() failed
Wed Nov 14 06:07:33 query failed : admin.$cmd { shutdown: 1.0 } to: 127.0.0.1:27017
server should be down...
Wed Nov 14 06:07:33 trying reconnect to 127.0.0.1:27017
Wed Nov 14 06:07:33 reconnect 127.0.0.1:27017 failed couldnt connect to server 127.0.0.1:27017
  • 修改配置文件,重启使配置生效
[root@izbp1b498epn4trb75oykez mongoDB]# vi mongodb.conf

配置文件内容

#端口号 默认27017
port=27017
#绑定ip 默认127.0.0.1只允许本地连接
bind_ip = 0.0.0.0

#数据目录
dbpath = /usr/local/mongoDB/data/db

#日志文件
logpath = /usr/local/mongoDB/logs/mongoLogs.log

#设置后台运行
fork = true

#日志输出方式
logappend = true

#开启身份验证
auth = true

重启

[root@izbp1b498epn4trb75oykez bin]# ./mongod --config /usr/local/mongoDB/mongodb.conf 
  • 以管理员账号登录,创建普通用户,之后本地做开发连接数据库时需要配置账号密码才可以成功连接
1,以管理员账号连接数据库
[root@izbp1b498epn4trb75oykez bin]# ./mongo 127.0.0.1:27017/admin --username "root" --password "123456"
2,创建数据库,创建账号,给读写权限
> use blog
> db.createUser({user:"blogAdmin",pwd:"123456",roles:[{role:"readWrite",db:"blog"}]})
Successfully added user: {
	"user" : "blogAdmin",
	"roles" : [
    	{
	    	"role" : "readWrite",
	    	"db" : "blog"
    	}
	]
}

四、开放对外端口,远程连接

  • 如果是阿里云主机需要在阿里云控制台开启27017端口,然后在服务器命令行开启相应端口,然后重启防火墙生效
1,查看防火墙状态
[root@izbp1b498epn4trb75oykez redis]# systemctl status firewalld
2,开启27017端口
[root@izbp1b498epn4trb75oykez redis]# firewall-cmd --zone=public --add-port=27017/tcp --permanent
success
3,重启防火墙
[root@izbp1b498epn4trb75oykez redis]# firewall-cmd --reload
4,查看端口号是否开放成功,输出yes开放成功,no则失败
[root@izbp1b498epn4trb75oykez redis]# firewall-cmd --zone=public --query-port=27017/tcp
  • 如果是其他主机可以参考这篇文章
  • 端口开放成功后可以使用Navicat连接测试

  • 连接成功,由于数据库中没有内容所以显示的是空白

  • 开发中连接中使用,各个语言连接工具不一定相同这里以nodejs举例
import mongoose from 'mongoose';
const db = mongoose.connect('mongodb://blogAdmin:123456@[你的IP]:27017/blog', { useNewUrlParser: true }, err => {
  if (err) {
    console.log('出错---------->', err)
  } else {
    console.log('链接成功')
  }
})

五、用户权限角色说明

Read:允许用户读取指定数据库

readWrite:允许用户读写指定数据库

dbAdmin:允许用户在指定数据库中执行管理函数,如索引创建、删除,查看统计或访问system.profile

userAdmin:允许用户向system.users集合写入,可以找指定数据库里创建、删除和管理用户

clusterAdmin:只在admin数据库中可用,赋予用户所有分片和复制集相关函数的管理权限。

readAnyDatabase:只在admin数据库中可用,赋予用户所有数据库的读权限

readWriteAnyDatabase:只在admin数据库中可用,赋予用户所有数据库的读写权限

userAdminAnyDatabase:只在admin数据库中可用,赋予用户所有数据库的userAdmin权限

dbAdminAnyDatabase:只在admin数据库中可用,赋予用户所有数据库的dbAdmin权限。

root:只在admin数据库中可用。超级账号,超级权限。

六、完成

  • 至此linux安装mongodb与远程连接全部完成,描述过程中如有不准确或讲解不清楚的地方欢迎在评论区留言斧正,撒花🎉🎉🎉🎉