MongoDB【部署 02】mongodb使用配置文件启动、添加为系统服务及自启动(一个报错:[13436][NotMasterOrSecondary])

本文涉及的产品
云数据库 MongoDB,独享型 2核8GB
推荐场景:
构建全方位客户视图
日志服务 SLS,月写入数据量 50GB 1个月
简介: MongoDB【部署 02】mongodb使用配置文件启动、添加为系统服务及自启动(一个报错:[13436][NotMasterOrSecondary])

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

dbPathsytemLog.path配置的目录必须存在且可写否则无法启动【重要的事情说好几遍】。详细的配置说明:https://www.mongodb.com/docs/v6.0/reference/configuration-optionssecurity的相关配置我们随后再聊。

  • 一个报错:[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提供了更先进的服务管理和自启动机制,允许更灵活地管理系统服务,并提供了更多的功能和控制选项。

相关实践学习
MongoDB数据库入门
MongoDB数据库入门实验。
快速掌握 MongoDB 数据库
本课程主要讲解MongoDB数据库的基本知识,包括MongoDB数据库的安装、配置、服务的启动、数据的CRUD操作函数使用、MongoDB索引的使用(唯一索引、地理索引、过期索引、全文索引等)、MapReduce操作实现、用户管理、Java对MongoDB的操作支持(基于2.x驱动与3.x驱动的完全讲解)。 通过学习此课程,读者将具备MongoDB数据库的开发能力,并且能够使用MongoDB进行项目开发。   相关的阿里云产品:云数据库 MongoDB版 云数据库MongoDB版支持ReplicaSet和Sharding两种部署架构,具备安全审计,时间点备份等多项企业能力。在互联网、物联网、游戏、金融等领域被广泛采用。 云数据库MongoDB版(ApsaraDB for MongoDB)完全兼容MongoDB协议,基于飞天分布式系统和高可靠存储引擎,提供多节点高可用架构、弹性扩容、容灾、备份回滚、性能优化等解决方案。 产品详情: https://www.aliyun.com/product/mongodb
目录
相关文章
|
6月前
|
NoSQL MongoDB Python
【Python】已完美解决(MongoDB安装报错)Service ‘MongoDB Server (MongoDB)’ (MongoDB) failed tostart
【Python】已完美解决(MongoDB安装报错)Service ‘MongoDB Server (MongoDB)’ (MongoDB) failed tostart
345 1
|
2月前
|
NoSQL 容灾 MongoDB
MongoDB主备副本集方案:两台服务器使用非对称部署的方式实现高可用与容灾备份
在资源受限的情况下,为了实现MongoDB的高可用性,本文探讨了两种在两台服务器上部署MongoDB的方案。方案一是通过主备身份轮换,即一台服务器作为主节点,另一台同时部署备节点和仲裁节点;方案二是利用`priority`设置实现自动主备切换。两者相比,方案二自动化程度更高,适合追求快速故障恢复的场景,而方案一则提供了更多的手动控制选项。文章最后对比了这两种方案与标准三节点副本集的优缺点,指出三节点方案在高可用性和数据一致性方面表现更佳。
118 5
|
3月前
|
存储 NoSQL MongoDB
基于阿里云数据库MongoDB版,微财数科“又快又稳”服务超7000万客户
选择MongoDB主要基于其灵活的数据模型、高性能、高可用性、可扩展性、安全性和强大的分析能力。
|
2月前
|
存储 NoSQL MongoDB
【赵渝强老师】部署MongoDB复制集
本文介绍了如何在单个节点上搭建MongoDB复制集环境,通过监听不同端口实现多节点配置。详细步骤包括创建数据目录、编辑配置文件、启动节点、初始化复制集、查看状态以及测试主从库的读写操作。文中还提供了视频讲解和代码示例,帮助读者更好地理解和操作。
|
5月前
|
存储 NoSQL MongoDB
今日分享MongoDB一键部署脚本
今日分享MongoDB一键部署脚本
48 0
|
6月前
|
DataWorks NoSQL fastjson
DataWorks操作报错合集之DataX进行MongoDB全量迁移的过程中,DataX的MongoDB Reader插件在初始化阶段找不到Fastjson 2.x版本的类库,该怎么办
DataWorks是阿里云提供的一站式大数据开发与治理平台,支持数据集成、数据开发、数据服务、数据质量管理、数据安全管理等全流程数据处理。在使用DataWorks过程中,可能会遇到各种操作报错。以下是一些常见的报错情况及其可能的原因和解决方法。
|
7月前
|
分布式计算 DataWorks NoSQL
DataWorks操作报错合集之从MongoDB同步数据到MaxCompute(ODPS)时,出现报错,该怎么解决
DataWorks是阿里云提供的一站式大数据开发与治理平台,支持数据集成、数据开发、数据服务、数据质量管理、数据安全管理等全流程数据处理。在使用DataWorks过程中,可能会遇到各种操作报错。以下是一些常见的报错情况及其可能的原因和解决方法。
DataWorks操作报错合集之从MongoDB同步数据到MaxCompute(ODPS)时,出现报错,该怎么解决
|
6月前
|
NoSQL Shell MongoDB
【Python】已解决:(MongoDB安装报错)‘mongo’ 不是内部或外部命令,也不是可运行的程序
【Python】已解决:(MongoDB安装报错)‘mongo’ 不是内部或外部命令,也不是可运行的程序
633 0
|
22天前
|
存储 JSON NoSQL
学习 MongoDB:打开强大的数据库技术大门
MongoDB 是一个基于分布式文件存储的文档数据库,由 C++ 编写,旨在为 Web 应用提供可扩展的高性能数据存储解决方案。它与 MySQL 类似,但使用文档结构而非表结构。核心概念包括:数据库(Database)、集合(Collection)、文档(Document)和字段(Field)。MongoDB 使用 BSON 格式存储数据,支持多种数据类型,如字符串、整数、数组等,并通过二进制编码实现高效存储和传输。BSON 文档结构类似 JSON,但更紧凑,适合网络传输。
60 15
|
30天前
|
存储 NoSQL 关系型数据库
阿里云数据库MongoDB版助力信也科技 打造互联网金融企业样板
我们的风控系统引入阿里云数据库MongoDB版后,解决了特征类字段灵活加减的问题,大大提高了开发效率,极大的提升了业务用户体验,获得了非常好的效果
阿里云数据库MongoDB版助力信也科技 打造互联网金融企业样板