MongoDB的安装与连接

学习资源

MongoDB中文网
https://www.mongodb.org.cn/tutorial/6.html
菜鸟教程
https://www.runoob.com/mongodb/mongodb-linux-install.html

官网教程:最好(别的教程具有时效性,官方的文档最权威)
https://docs.mongodb.com/manual/tutorial/install-mongodb-on-ubuntu/
踩了几个小坑,网上多数的MongoDB教程已经过时了,因此出一篇关于MongoDB的安装与使用,此篇主要是安装

安装mongodb

第一种 apt-get(推荐)

按照官网的教程来安装(如果失败可能是时间过久,就像很多教程一样,过期了,请自行前往官网的文档安装)
地址:https://docs.mongodb.com/manual/
wget 下载链接
sudo dpkg -i 包名(deb包)
sudo apt-get install -y mongodb-org

即安装完成

第二种 tar解压缩(不推荐)

下载tar压缩包
wget 下载链接

解压缩
tar -zxvf 包名.tgz

添加环境变量
sudo cp /bin/* /usr/local/bin/
将解压缩后的bin目录下的文件 全部复制到 用户的环境变量文件夹下,然后更新环境变量

安装mongosh

https://www.mongodb.com/try/download/shell?jmp=docs
可以在本地安装mongosh.msi 然后连接服务器的mongodb(推荐)
安装后,连接mongodb
在这里插入图片描述

服务器安装mongosh
wget 下载链接deb
sudo dpkg -i 包名(deb包)
sudo apt-get install -y mongodb-mongosh
使用同理

配置

配置文件所在 /etc/mongod.conf
找到配置文件,然后修改

如果不是通过 apt get方式安装的mongdb,通过tar解压安装(不建议),则需要自己创建config文件

修改完 重启即可
sudo systemctl restart mongod
sudo systemctl stop mongod
sudo systemctl start mongod

验证是否启动成功
sudo systemctl status mongod

mongosh 查看当前mongod 状态
mongosh

附config内容

# mongod.conf

# for documentation of all options, see:
#   http://docs.mongodb.org/manual/reference/configuration-options/

# Where and how to store data.
storage:
  dbPath: /var/lib/mongodb(不允许修改)
  journal:
    enabled: true


# where to write logging data.
systemLog:
  destination: file
  logAppend: true
  path:  /var/log/mongodb/mongod.log(不允许修改)

# network interfaces
net:
  port: 27017
  bindIp: 0.0.0.0(必须要修改)


# how the process runs
processManagement:
  timeZoneInfo: /usr/share/zoneinfo

启动

第一种启动方式

sudo systemctl start mongod
开启默认端口 27017 且不允许修改配置文件的 db 和 log位置,改了就无法启动
如果出现 Failed to start mongod.service: Unit mongod.service not found.
则 sudo systemctl daemon-reload

停止:sudo systemctl stop mongod

重启:sudo systemctl restart mongod

查看状态:sudo systemctl status mongod

第二种启动方式(推荐)

将配置文件拷贝一份,然后可以自定义db 和log 文件的位置,且可以开启多个Mongodb,监听不同端口
启动举例:mongod -f /root/MongoDB/mongodb.cfg --fork

停止:mongod -f /root/MongoDB/mongodb.cfg --fork

中间 -f 后面就是新配置文件的所在地,fork启动不会默认使用配置文件,必须要加入-f 参数,否则默认监听本地,外部无法连接

storage:
  dbPath: /var/lib/mongodb(允许修改)
  journal:
    enabled: true

systemLog:
  destination: file
  logAppend: true
  path:  /var/log/mongodb/mongod.log(允许修改)

net:
  port: 27017(要监听的端口)
  bindIp: 0.0.0.0(必须要修改)
  
processManagement:
  timeZoneInfo: /usr/share/zoneinfo

连接

使用Navcat连接,输入服务器ip地址,端口即可
在这里插入图片描述

安全加密

在配置文件中,默认不启动身份验证,也就是说只要知道你的ip地址,就可以操作数据库里的全部数据,显然不太安全

因此开启身份验证,只允许自己登录

在配置文件中加入
security:
authorization: enabled
在这里插入图片描述
然后运行mongosh 创建用户管理员

mongosh
use admin
db.createUser(
{
user: “myUserAdmin”,
pwd: passwordPrompt(), // or cleartext password
roles: [ { role: “userAdminAnyDatabase”, db: “admin” }, “readWriteAnyDatabase” ]
}
)

创建后 想要再创建用户,需要mongosh 认证账号和密码
关闭 mongodb ,重新启动
然后 mongosh
use admin
db.auth(“myUserAdmin”, passwordPrompt())
输入密码即可再创建新的用户

再次连接 使用admin 数据库,这是用户认证数据库,所有用户在里面
在这里插入图片描述

posted @ 2021-07-31 17:21  euph  阅读(205)  评论(0编辑  收藏  举报