Linux上安装MongoDB
使用本教程使用.rpm 软件包在红帽企业Linux或CentOS Linux版本6和7上安装MongoDB Community Edition 。
软件包
MongoDB在他们自己的仓库中提供官方支持的包。该存储库包含以下软件包:
| 包裹名字 | 描述 |
|---|---|
mongodb-org |
A metapackage将自动安装下面列出的四个组件软件包。 |
mongodb-org-server |
包含mongod守护进程和相关的配置以及init脚本。 |
mongodb-org-mongos |
包含mongos守护进程。 |
mongodb-org-shell |
包含mongo外壳。 |
mongodb-org-tools |
包含以下的MongoDB工具:,,, , ,,,和。mongoimportbsondumpmongodumpmongoexportmongofilesmongoperfmongorestoremongostatmongotop |
该mongodb-org-server软件包提供了一个mongod以/etc/mongod.conf 配置文件开始的初始化脚本。
有关使用此初始化脚本的详细信息,请参阅运行MongoDB Community Edition。
/etc/mongod.conf软件包提供的默认配置文件默认bind_ip设置为127.0.0.1。在初始化副本集之前根据您的环境需要修改此设置 。
安装MongoDB社区版
注意
要安装不同版本的MongoDB,请参考该版本的文档。例如,参见3.4版。
本安装指南仅支持64位系统。详细信息请参见平台支持。
配置包管理系统(yum)。
创建一个/etc/yum.repos.d/mongodb-org-3.6.repo文件,以便您可以直接使用安装MongoDB yum。
版本3.0更改: MongoDB Linux软件包位于以3.0开头的新存储库中。
对于MongoDB
使用以下存储库文件:
[mongodb-org-3.6]
name=MongoDB Repository
baseurl=https://repo.mongodb.org/yum/redhat/$releasever/mongodb-org/3.6/x86_64/
gpgcheck=1
enabled=1
gpgkey=https://www.mongodb.org/static/pgp/server-3.6.asc
MongoDB的版本早比3.6
要从早期版本系列(如3.4)安装软件包,可以在存储库配置中指定版本系列。例如,要将系统限制到3.4版系列,请创建一个 /etc/yum.repos.d/mongodb-org-3.4.repo文件以保存MongoDB 3.4存储库的以下配置信息:
[mongodb-org-3.4]
name=MongoDB 3.4 Repository
baseurl=https://repo.mongodb.org/yum/redhat/$releasever/mongodb-org/3.4/x86_64/
gpgcheck=0
enabled=1
您可以在存储库本身中找到.repo每个版本的文件。请记住,奇数次版本(例如3.5)是开发版本,不适合生产使用。
安装MongoDB软件包。
要安装最新的稳定版本的MongoDB,请发出以下命令:
sudo yum install -y mongodb-org
要安装特定版本的MongoDB,请分别指定每个组件包并将版本号附加到包名称,如下例所示:
sudo yum install -y mongodb-org-3.6.3 mongodb-org-server-3.6.3 mongodb-org-shell-3.6.3 mongodb-org-mongos-3.6.3 mongodb-org-tools-3.6.3
您可以指定任何可用的MongoDB版本。但是yum ,当更新的版本可用时,将升级软件包。为防止意外升级,请钉住包装。要固定包装,请将以下exclude指令添加到您的/etc/yum.conf文件中:
exclude=mongodb-org,mongodb-org-server,mongodb-org-shell,mongodb-org-mongos,mongodb-org-tools
运行MongoDB社区版
大多数类Unix操作系统会限制会话可能使用的系统资源。这些限制可能会对MongoDB的运营产生负面影响。有关更多信息,请参阅UNIX ulimit设置。
配置
重要
如果您使用的是SELinux,则必须配置SELinux以允许MongoDB在基于Red Hat Linux的系统(红帽企业Linux或CentOS Linux)上启动。
要配置SELinux,管理员有三种选择:
如果SELinux处于
enforcing模式,则允许访问MongoDB部署将使用的相关端口(例如27017)。有关MongoDB默认端口的更多信息,请参阅默认MongoDB端口。对于默认设置,这可以通过运行来完成semanage port -a -t mongod_port_t -p tcp 27017
将
SELINUX设置设置为disabledin,禁用SELinux/etc/selinux/config。SELINUX=disabled
您必须重新启动系统才能使更改生效。
通过将设置设置为,将SELinux设置为
permissive模式。/etc/selinux/configSELINUXpermissiveSELINUX=permissive
您必须重新启动系统才能使更改生效。
您可以改用
setenforce更改为permissive模式。setenforce不需要重启,但不是持久的。
或者,您可以选择在安装Linux操作系统时不安装SELinux软件包,或选择删除相关软件包。该选项是最具侵入性的,不推荐。
数据目录和权限
警告
在RHEL 7.0上,如果更改数据路径,则如果不更改安全上下文,则默认的 SELinux策略将阻止mongod对新数据路径拥有写入权限。
MongoDB实例默认存储其数据文件/var/lib/mongo 及其日志文件/var/log/mongodb,并使用mongod 用户帐户运行。您可以在中指定备用日志和数据文件目录/etc/mongod.conf。请参阅systemLog.path 并storage.dbPath获取更多信息。
如果更改运行MongoDB进程的用户,则 必须修改/var/lib/mongo和 /var/log/mongodb目录的访问控制权限,以使该用户可以访问这些目录。
程序
启动MongoDB。
您可以mongod通过发出以下命令来启动进程:
sudo service mongod start pm2启动的话 使用pm2 start mongo
在这里启动mongo 会出现一些问题:比方说对端口进行配置,有一个和tomcat类似的配置文件mongod.conf可以修改我们的端口,同时也要对防火墙惊醒修改
确认MongoDB已成功启动
您可以mongod通过检查日志文件的内容以/var/log/mongodb/mongod.log 查看行数来验证过程是否已成功启动
[initandlisten] waiting for connections on port <port>
其中<port>被配置为在该端口/etc/mongod.conf,27017默认情况下。
您可以选择通过发出以下命令来确保MongoDB在启动系统后启动:
sudo chkconfig mongod on
重新启动MongoDB。
您可以mongod通过发出以下命令来重新启动进程:
sudo service mongod restart
您可以通过查看/var/log/mongodb/mongod.log文件中的输出来跟踪错误或重要消息的进程状态。
卸载MongoDB Community
要从系统中完全删除MongoDB,您必须删除MongoDB应用程序本身,配置文件以及包含数据和日志的任何目录。以下部分将指导您完成必要的步骤。
警告
此过程将彻底删除MongoDB及其配置和所有 数据库。这个过程是不可逆的,因此请确保在继续之前备份所有配置和数据。
删除包。
删除以前安装的任何MongoDB软件包。
sudo yum erase $(rpm -qa | grep mongodb-org)
删除数据目录。
删除MongoDB数据库和日志文件。
sudo rm -r /var/log/mongodb
sudo rm -r /var/lib/mongo 相关文档:https://docs.mongodb.com/manual/tutorial/install-mongodb-on-red-hat/
Linux上安装MongoDB的更多相关文章
- linux上安装MongoDB副本集(带keyfile安全认证以及用户权限)
搭建前准备 MongoDB版本:4.0 主要参考搭建MongoDB副本集网站:https://www.jianshu.com/p/f021f1f3c60b 安装之前最好先确定一下几点: 防火墙关闭 M ...
- Linux上安装 MongoDB ZK MEMCACHE PHP扩展
安装mongo扩展: 下载地址:https://github.com/mongodb/mongo-php-driver,下载该源码包 /usr/local/php/bin/pecl install m ...
- 在 CentOS7 上安装 MongoDB
在 CentOS7 上安装 MongoDB 1 通过 SecureCRT 连接至 CentOS7 服务器: 2 进入到 /usr/local/ 目录: cd /usr/local 3 在当前目录下创建 ...
- 在Windows上安装MongoDB
原文官方文档:https://docs.mongodb.org/v2.6/tutorial/install-mongodb-on-windows/ 基于版本:MongoDB 2.6 概览 通过这个示例 ...
- Linux平台安装MongoDB及使用Docker安装MongoDB
一.Linux平台安装MongoDB MongoDB 提供了 linux 各发行版本 64 位的安装包,你可以在官网下载安装包. 下载地址:https://www.mongodb.com/downlo ...
- (转)在 CentOS7 上安装 MongoDB
在 CentOS7 上安装 MongoDB 1 通过 SecureCRT 连接至 CentOS7 服务器: 2 进入到 /usr/local/ 目录: cd /usr/local 3 在当前目录下创建 ...
- 如何在 Ubuntu 上安装 MongoDB
MongoDB 是一个越来越流行的自由开源的 NoSQL 数据库,它将数据存储在类似 JSON 的灵活文档集中,这与 SQL 数据库中常见的表格形式形成对比. 你很可能发现在现代 Web 应用中使用 ...
- 如何在CentOS/RHEL & Fedora上安装MongoDB 3.2
MongoDB(名称取自"huMONGOus")是一个有着全面灵活的索引支持和丰富的查询的数据库.MongoDB通过GridFS提供强大的媒体存储.点击这里获取MongoDB的更多 ...
- 在Windows和Linux上安装paramiko模块以及easy_install的安装方法
一.paramiko模块有什么用? paramiko是用python语言写的一个模块,遵循SSH2协议,支持以加密和认证的方式,进行远程服务器的连接.由于使用的是python这样的能够跨平台运行的语言 ...
随机推荐
- vector.clear()的内存泄露问题
在使用vector的过程中,经常会遇到以下场景 vector<int> vec; ) { vec.push_back(); vec.push_back(); vec.push_back() ...
- HDU 1074状压DP
Doing Homework Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)To ...
- 手脱ACProtect V2.0(无Stolen Code)
1.载入PEID ACProtect V2.0 -> risco 2.载入OD > 00A04000 push ACP_Feed.0040A000 ; //入口点 0B104000 pus ...
- C++ 什么是多态
一.什么是多态(Polymorphism) 多态(Polymorphism)是面向对象(Object-Oriented,OO)思想"三大特征"之一,其余两个分别是封装(Encaps ...
- [解决] HiveServer2中使用jdbc访问hbase时导致ZooKeeper连接持续增加的解决
最近在监控中发现HiveServer2连接到zookeeper里的连接持续上涨,很奇怪,虽然知道HiveServer2支持并发连接,使用ZooKeeper来管理Hive表的读写锁,但我们的环境并不需要 ...
- Moodle插件开发系列——XMLDB编辑器
Moodle插件开发系列——XMLDB编辑器 位置:网站管理>开发> XML编辑器 l XML编辑器是制作install.xml文件的工具,而install.xml是指定Moodle建立 ...
- Spring Boot 启动报错 Exception in thread "main" java.lang.StringIndexOutOfBoundsException: String index out of range: 37
使用命令 java -jar springBoot.jar 启动项目,结果报错如下: Exception at java.lang.String.substring(String.java:) at ...
- mysql 中 group_concat()用法
基本语法:group_concat([DISTINCT] 要连接的字段 [Order BY 排序字段 ASC/DESC] [Separator '分隔符']) 初始数据: ...
- ajax 请求数据的两种方法
实现ajax 异步访问网络的方法有两个.第一个是原始的方法,第二个是利用jquery包的 原始的方法不用引入jquery包,只需在html中编写script 片段 这里我演示的是一个传递参数查询的例子 ...
- 51Nod 1024 矩阵中不重复的元素 | 技巧 数学
first try: set<LL> sset; int main() { LL m,n,a,b; while(~scanf("%lld%lld%lld%lld",&a ...