什么是MongoDB
MongoDB是由C++语言编写的,是一个具有分布式文件存储的开源数据库系统。MongoDB将数据存储为一个文档,数据结构由键值对组成,类似于JSON对象,字段本身还可以包含其他文档,数组等。
MongoDB的特点
- 易于使用
MongoDB是一个面向文档的数据库,其中没有行的概念,取而代之的是更加灵活的文档,这与使用现代面向对象语言的开发者对数据的看法一致。另外文档的键值不再是固定的类型和大小,没有固定的格式,这样根据需求添加或删除字段会变得更加容易。 - 易于扩展
MongoDB的设计采用横向扩展,即通过分区将数据分散到更多的机器上。而面向文档的数据模型也能够非常容易地在多台服务器之间进行数据分割。MongoDB能自动处理跨集群的数据和负载。
MongoDB的安装
MongoDB分为社区版和企业版。我们以安装社区版为例目前最新版本为4.2.3。
从官网下载地址中下载社区版安装文件
运行安装程序,下一步即可,需要注意的是从MongoDB4.0开始,可以在安装过程中将MongoDB设置为Windows服务,当然也可以仅安装二进制文件:
选择Install MongoDB as a Service就可以将其作为服务安装。
其与默认即可,需要说明的是:
- Data Directory:指定数据目录,它对应--dbpath选项
- Log Directory: 指定日志目录,对应--logpath选项
- 以上设置位于MongoDB安装目录下bin文件夹的mogod.cfg配置文件中
安装完成后默认已经开启了MongoD服务了,此时你可以在MongoDB安装目录中的bin目录下找到mongo.exe双击就可以打开MongoDB shell连接到正在运行的实例了。也可以将其添加到系统的Path环境变量中,直接在CMD中运行mongo
你可以在Windows服务中找到MongoDB服务来启停他们:
没有将MongoDB安装为Windows服务
如果没有选择Install MongoDB as a Service,就必须手动启动MongoDB实例,此时就需要在CMD中启动他们,首先需要以管理员身份打开cmd,执行以下操作:
- 创建数据库目录
创建MongoDB存储数据的数据目录:
cd C:\
md \data\db
# MongoDB的默认数据目录路径就是C:\data\db文件夹中
# 你也可以直接使用 --dbpath 指定
- 启动MongoDB服务器
C:\Program Files\MongoDB\Server\4.2\bin\mongod.exe --dbpath = C:\data\db
此时你就开启了一个MongoDB服务器
- 连接到MongoDB
也是通过mongo.exe程序来连接,但是需要注意的是需要保证启动MongoDB服务器的cmd窗口不能被关闭,一旦关闭就意味着服务停止。
Linux下安装
这里以Ubuntu为例,直接使用 sudo apt-get install -y mongodb-org命令安装就可以了。不过需要注意的是MongoDB4.2停止了对Ubuntu14.04的支持以及对Ubuntu16.04 ARM64上的支持。
- 目录:通过apt安装时在安装过程中将创建数据目录/var/lib/mongodb和日志目录/var/log/mongodb
- 配置文件:位于/etc/mongod.conf,这些设置启动时生效,这也意味着每次更改配置都要重启实例
Linux下启动服务
- 启动MongoDB服务
sudo systemctl start mongod
如果出现了错误,可以执行以下命令来重新加载守护进程
sodo systemctl daemon-reload
- 验证MongoDB已成功启动
sudo systemctl status mongod
- 确保系统重启后启动mongod服务
sudo systemctl enable mongod
- 停止Mongod服务
sudo systemctl stop mongod
- 重新启动
sudo systemctl restart mongod
网络配置
默认情况下,MongoDB在启动时bindIp被设置为127.0.0.1,即绑定到localhost网口,这也意味着mongod只能接受来自同一计算机上运行的客户端的连接,除非将此值设置为有效的网络接口,否则远程客户端将无法连接到mongod,并且mongod不能初始化副本集。
当然这也是可配置的:
- 在MongoDB配置文件中bondIp中设置,记着设置后重启服务
- 通过命令行参数 --bind_ip来指定,这也意味着重启