1.是什么
【以下内容来自ChatGPT3.5】
MongoDB是一个流行的开源文档型数据库管理系统,广泛用于构建高度可扩展、灵活和性能卓越的应用程序。以下是MongoDB的一些关键特点和概念的详细介绍:
- 文档型数据库:数据以类似JSON的BSON(二进制JSON)格式存储,这种格式非常灵活,能够存储各种不同结构的数据。
- NoSQL数据库:与传统的关系型数据库不同,它不需要预定义模式,可以根据需要动态地改变数据模型。
- 集合和文档:MongoDB中的数据组织方式是通过集合(Collection)和文档(Document)。文档是一种键值对的数据结构,集合包含一组文档。
- 灵活的数据模型:支持多种数据类型,包括嵌套文档、数组和各种原始数据类型,这使得数据建模非常灵活。
- 自动分片和复制:具有内置的数据分片和复制功能,可以水平扩展,提高性能和可用性。数据可以自动分布到多个服务器上,同时还可以配置自动故障恢复和冗余备份。
- 丰富的查询功能:支持强大的查询功能,包括复杂的条件查询、范围查询、正则表达式查询等。还支持地理空间查询,这对于地理信息系统(GIS)应用非常有用。
- 索引:支持多种索引类型,可以提高查询性能。开发人员可以根据应用程序的需求创建自定义索引。
- 聚合框架:提供了一个强大的聚合框架,可以用于数据分析、数据处理和数据转换等复杂操作。
- 丰富的驱动程序支持:有大量的官方和第三方驱动程序,支持多种编程语言,包括Java、Python、Node.js、Ruby等,使得开发人员可以轻松地与数据库进行交互。
- 安全性:提供了身份验证、授权、数据加密和安全审计等功能,以确保数据的安全性。
- 开源和社区支持:MongoDB是开源的,拥有强大的社区支持,有活跃的社区维护和更新。
MongoDB适用于各种应用场景,特别是需要处理大量非结构化或半结构化数据的应用,例如社交媒体应用、内容管理系统、物联网(IoT)应用、日志分析和数据仓库等。由于其灵活性、可扩展性和性能,MongoDB已成为当今流行的数据库选择之一。
2.下载安装启动配置
2.1 下载
安装环境为CentOS7.7
:
[root@tcloud ~]# cat /etc/centos-release CentOS Linux release 7.7.1908 (Core)
从官网 https://www.mongodb.com/try/download/community 选择版本和部署环境,下载对应的安装包,本次安装的是 Vesion:6.0.10 Platform:RedHat/CentOS 7.0 x64 Package:tgz
详细地址为:https://fastdl.mongodb.org/linux/mongodb-linux-x86_64-rhel70-6.0.10.tgz
2.2 安装
# 1.解压并重命名 tar -zxvf mongodb-linux-x86_64-rhel70-6.0.10.tgz mv mongodb-linux-x86_64-rhel70-6.0.10 mongodb # 2.创建数据存放目录data和日志目录logs cd mongodb mkdir data && mkdir logs
MongoDB 服务在启动时需要指定数据存储的目录。如果没有指定的话,默认会存储到 /data/db/ 目录,如果数据目录不存在或不可写,那么服务器端将无法启动。
传参启动(上一篇已介绍)这里简单贴出【不作为标题】
# 启动命令 bin/mongod --fork --dbpath=/home/mongodb/data --logpath=/home/mongodb/logs/mongodb.log # 输出信息 about to fork child process, waiting until server is ready for connections. forked process: 9577 child process started successfully, parent exiting # 停止命令 bin/mongod --shutdown --dbpath=/home/mongodb/data --logpath=/home/mongodb/logs/mongodb.log # 输出信息 {"t":{"$date":"2023-09-19T03:48:59.044Z"},"s":"I", "c":"CONTROL", "id":20697, "ctx":"-","msg":"Renamed existing log file","attr":{"oldLogPath":"/home/mongodb/logs/mongodb.log","newLogPath":"/home/mongodb/logs/mongodb.log.2023-09-19T03-48-59"}} Killing process with pid: 9577
- fork:在后台运行 mongod 进程,将 MongoDB 服务作为守护进程运行,如果指定了fork,则必须同时指定logpath。
- dbpath:指定 MongoDB 数据库文件的存储路径,启动服务时必须指定。
- logpath:指定 MongoDB 日志文件的存储路径,默认日志是打印在命令行中的。如果对此目录有写权限且文件不存在,则会自动创建该文件。如果日志文件已经存在,默认会覆盖掉该文件,并删除所有旧的日志。如果希望保留旧的日志,除了使用 logpath 之外,还应该使用logappend 选项。
查看启动状态:
# 监听端口 lsof -i :27017 # 输出信息 COMMAND PID USER FD TYPE DEVICE SIZE/OFF NODE NAME mongod 9577 root 14u IPv4 20996700 0t0 TCP VM-0-8-centos:27017 (LISTEN) # 或 ps -ef | grep mongo # 输出信息 root 9577 1 0 Sep19 ? 00:05:54 bin/mongod --config /home/mongodb/mongodb.conf
2.3 配置
在mongdb目录下创建配置文件mongdb.conf
:
# 创建目录 cd /home/mongodb vim mongodb.conf
配置文件内容如下:
# 存储相关配置 storage: dbPath: /home/mongodb/data journal: enabled: true # 这个缓存用于存储MongoDB数据的索引和数据文件,以提高读取性能。 wiredTiger: engineConfig: cacheSizeGB: 1 # 网络相关配置 net: bindIp: tcloud port: 27017 # 日志相关配置 systemLog: destination: file path: /home/mongodb/logs/mongod.log logAppend: true # 安全相关配置【开发或测试环境可不启动】 security: authorization: disabled # 后台启动 processManagement: fork: true
dbPath
和sytemLog.path
配置的目录必须存在且可写否则无法启动【重要的事情说好几遍】。详细的配置说明:https://www.mongodb.com/docs/v6.0/reference/configuration-options。security
的相关配置我们随后再聊。
- 一个报错:[13436][NotMasterOrSecondary] node is not in primary or recovering state
# 单机版错误配置了复制集相关配置 replication: replSetName: tcloud
2.4 使用配置文件启动
# 使用配置文件启动 bin/mongod --config /home/mongodb/mongodb.conf # 启动详情 [root@tcloud mongodb]# bin/mongod --config /home/mongodb/mongodb.conf about to fork child process, waiting until server is ready for connections. forked process: 22676 child process started successfully, parent exiting
3.设置系统服务及自启动
3.1 设置为系统服务
将MongoDB设置成系统服务,就可以通过systemctl
进行启动停止重启,在目录/etc/systemd/system
下编写mongodb.service
文件:
vim /etc/systemd/system/mongodb.service
文件内容:
[Unit] Description=MongoDB Database Server Documentation=https://www.mongodb.com/docs/ After=network.target [Service] ExecStart=/home/mongodb/bin/mongod --config /home/mongodb/mongodb.conf ExecReload=/bin/kill -s HUP $MAINPID ExecStop=/home/mongodb/bin/mongod --shutdown --config /home/mongodb/mongodb.conf Restart=always LimitNOFILE=64000 LimitNPROC=64000 [Install] WantedBy=multi-user.target
# 重新加载systemd服务配置 systemctl daemon-reload # 测试systemctl是否可以启动mongdb systemctl start mongodb
3.2 自启动
# 设置开机自启动 systemctl enable mongodb
现在,MongoDB已经被设置为系统自启,并可以使用以下systemctl命令进行管理:
systemctl start mongodb systemctl stop mongodb systemctl restart mongodb systemctl status mongodb
在如今的Linux系统中,服务自启动的配置通常放置在/etc/systemd/system目录下,而不是/etc/init.d目录下。这是因为systemd已经取代了传统的init.d系统初始化脚本,成为了许多Linux发行版的默认初始化系统。systemd提供了更先进的服务管理和自启动机制,允许更灵活地管理系统服务,并提供了更多的功能和控制选项。