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

MongoDB使用配置文件启动、添加为系统服务及设置自启动

  • 1.是什么
  • 2.下载安装启动配置
    • 2.1 下载
    • 2.2 安装
    • 2.3 配置
    • 2.4 使用配置文件启动
  • 3.设置系统服务及自启动
    • 3.1 设置为系统服务
    • 3.2 自启动

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/datajournal:enabled: true# 这个缓存用于存储MongoDB数据的索引和数据文件,以提高读取性能。wiredTiger:engineConfig:cacheSizeGB: 1
# 网络相关配置
net:bindIp: tcloudport: 27017
# 日志相关配置
systemLog:destination: filepath: /home/mongodb/logs/mongod.loglogAppend: true
# 安全相关配置【开发或测试环境可不启动】
security:authorization: disabled
# 后台启动
processManagement:fork: true

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

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/137407.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

41. Linux系统配置FTP服务器并在QT中使用QFtp实现文件上传

1. 说明 这篇博客主要记录一些在Linux系统中搭建FTP服务器时踩过的一些坑,以及在使用QFtp上传文件时需要注意的问题。 2. FTP环境搭建 在linux系统中,需要安装vsftpd,可以在终端中输入下面的命令进行安装: sudo apt-get install vsftpd使用上述命令安装后,系统中会有一…

ChunJun(OldNameIsFlinkX)

序言 ChunJun主要是基于Flink实时计算框架,封装了不同数据源之间的数据导入与导出功能.我们只需要按照ChunJun的要求提供原始与目标数据源的相关信息给Chunjun,然后它会帮我们生成能运行与Flink上的算子任务执行,这样就避免了我们自己去根据不同的数据源重新编辑读入与读出的方…

学习笔记|模数转换器|ADC原理|STC32G单片机视频开发教程(冲哥)|第十七集:ADC采集

文章目录 1.模数转换器(ADC)是什么?手册说明: 2.STC32G单片机ADC使用原理19.1.1 ADC控制寄存器(ADC_CONTR)19.1.2 ADC配置寄存器(ADCCFG)19.1.4ADC时序控制寄存器(ADCTIM)19.3 ADC相…

CSS盒子模型、列表样式

盒子模型 常用的html标签都可以看作一个盒子,称为盒子模型 盒子由四部分组成: content、padding、border、margin 边框 border:border-width(粗细) | border-style(样式) | border-color(颜色) #one{bor…

云原生的简单理解

一、何谓云原生? 一种构建和运行应用软件的方法 应用程序从设计之初即考虑到云的环境,原生为云而设计,在云上以最佳姿势运行,充分利用和发挥云平台的弹性分布式优势。 二、包括以下四个要素 采用容器化部署:实现云平…

蓝牙核心规范(V5.4)10.6-BLE 入门笔记之L2CAP

蓝牙篇之蓝牙核心规范(V5.4)深入详解汇总 1.概述 L2CAP负责协议复用、流量控制、服务数据单元(SDU)的分段和重组。它使用通道的概念来分隔在堆栈层之间传递的数据包序列。固定通道不需要设置,立即可用,并与特定的上层协议相关联。通道也可以通过指定的协议服务多路复用器…

湖南衡阳3D扫描在生物仿真研究的应用高精度三维扫描螃蟹-CASAIM中科广电

生物仿真研究与应用一直是科研及工艺品的热门方向,很多设计脱胎于生物本身,传统方式又大多只能以画师手绘为主,做到“纤毫毕现”极其困难,故而才有了“齐白石的虾”、“徐悲鸿的马”等出圈的艺术家的画作,对于某种生物…

深度学习论文: ISTDU-Net:Infrared Small-Target Detection U-Net及其PyTorch实现

深度学习论文: ISTDU-Net:Infrared Small-Target Detection U-Net及其PyTorch实现 ISTDU-Net:Infrared Small-Target Detection U-Net PDF: https://doi.org/10.1109/LGRS.2022.3141584 PyTorch代码: https://github.com/shanglianlm0525/CvPytorch PyTo…

jvm-sandbox-repeater源码解析-配置管理

一、配置初见 源码里提供的控制台截图如下:(怎么搭建自己去百度) 从中取出对应的配置如下: { "degrade": false, //阻断能力 "exceptionThreshold": 1000, //异常采样率 "httpEntrancePatterns&qu…

SunTorque亮相GAF2023数字化智能装配工程与装备技术大会

智能扭矩系统-智能拧紧系统-智能扭矩控制-SunTorque GAF2023数字化智能装配工程与装备技术大会在中国上海汽车会展中心盛大开幕,青创智通与装配领域、智能制造、数字化应用等相关先进智造技术的知名企业一齐亮相。 本次展会,我们带来了扭矩相关解决方案…

Vivado IP中Generate Output Products的设置说明

文章目录 Vivado IP中Generate Output Products的设置说明Synthesis OptionsRun Settings 官方文档中的介绍Generate Output ProductsSynthesis Options for IP 参考文献 Vivado IP中Generate Output Products的设置说明 在创建IP核时,将IP核的信息配置完成之后会弹…

数据预处理方式合集

删除空行 #del all None value data_all.dropna(axis1, howall, inplaceTrue) 删除空列 #del all None value data_all.dropna(axis0, howall, inplaceTrue) 缺失值处理 观测缺失值 观测数据缺失值有一个比较好用的工具包——missingno,直接传入DataFrame&…

面向面试知识-Redis

面向面试知识-Redis 什么是Redis 运行于内存的基于key-value的非关系型数据库。 一款开源的内存数据结构存储,用作数据库、缓存、消息代理等。(可以基于Redis实现分布式锁、以及消息队列) 发布订阅?? 对数据类型的操…

【操作系统笔记】内存分配

内存对齐 问题:为什么需要内存对齐呢? 主要原因是为了兼容,为了让程序可以运行在不同的处理器中,有很多处理器在访问内存的时候,只能从特定的内存地址读取数据。换个说法就是处理器每次只能从内存取出特定个数字节的数…

Spring Boot实现对超大文件进行异步压缩下载

在Web应用中,文件下载功能是一个常见的需求,特别是当你需要提供用户下载各种类型的文件时。本文将演示如何使用Spring Boot框架来实现一个简单而强大的文件下载功能。我们将创建一个RESTful API,通过该API,用户可以下载问价为ZIP压…

Python计算机二级知识点整理

1.当一个进程在运行过程中释放了系统资源后要调用 唤醒进程原语 唤醒进程原语是把进程从等待队列里移出到就绪队列并设置进程为就绪状态,当一个进程在运行过程中释放了系统资源后进入就绪状态,调用唤醒进程原语。 2. 3. 4.在希尔排序法中&#x…

免费开源 | 基于SSM的校园订餐系统

源码下载地址获取 关注并私信回复“订餐”,获取源码下载方式 一定要关注后发消息,否则系统限制无法回复消息 感谢开源!侵删! 一、功能实现 1. 前台模块 前台主要功能有:用户注册、用户登录、我的购物车、我的订单、…

人类认知的贝叶斯与机器的贝叶斯

贝叶斯原理是一种基于概率的分析方法,可以用来估计一个事件发生的概率。在人类认知和机器学习领域中,都有对应的贝叶斯原理。 人类认知的贝叶斯原理: 在人类认知研究中,贝叶斯原理被认为是一种重要的思维方式。人类的认知过程通常…

大数据与云计算实验一

检查是否开启 sudo service docker status 开启服务 sudo service docker start 运行服务 sudo docker run -itd -p 8080:80 nginx 查询ID docker ps -all 进入容器shell sudo docker exec -it <容器ID或容器名称> /bin/bash 找到/usr/share/nginx/html/index.…

DevSecOps内置安全保护

前言 随着DevOps的发展&#xff0c;DevOps大幅提升了企业应用迭代的速度。但同时&#xff0c;安全如果不能跟上步伐&#xff0c;不仅会抵消DevOps变革带来的提升&#xff0c;拖慢企业数字化转型进程&#xff0c;还会导致漏洞与风险不约而至。所以安全能力在全球范围内受到的重…