文档章节

在CentOS 6.x 64bit上安装MongoDB 3.2社区版

江边望海
 江边望海
发布于 2016/11/07 08:46
字数 789
阅读 213
收藏 0

基本安装步骤

参考: https://docs.mongodb.org/manual/tutorial/install-mongodb-on-red-hat/

1) 创建repo源文件:

sudo vim /etc/yum.repos.d/mongodb-org-3.2.repo

内容如下:

[mongodb-org-3.2]
name=MongoDB Repository
baseurl=https://repo.mongodb.org/yum/redhat/$releasever/mongodb-org/3.2/x86_64/
gpgcheck=0
enabled=1

2) 更新源,并安装

sudo yum -y update
sudo yum -y install mongodb-org

3) 配置SELinux

sudo vim /etc/selinux/config

SELINUX内容改为:

SELINUX=disabled

需要重启系统才能生效!

4) 修改防火墙,保证端口可以访问:

sudo iptables -A INPUT -p tcp --dport 27017 -j ACCEPT
sudo /etc/init.d/iptables save

5) 检查目录权限:

确保 /var/lib/mongo 和 /var/log/mongodb 目录中文件是属于mongod:mongod用户和组,如果不是可以手工修改:

sudo chown -R mongod:mongod /var/lib/mongo
sudo chown -R mongod:mongod /var/log/mongo

6) 添加到系统服务中:

sudo chkconfig --add mongod
sudo chkconfig mongod on

7) 关闭THP(Transparent Huge Pages)

sudo vim /etc/init.d/disable-transparent-hugepages

内容如下:

#!/bin/sh
### BEGIN INIT INFO
# Provides:          disable-transparent-hugepages
# Required-Start:    $local_fs
# Required-Stop:
# X-Start-Before:    mongod mongodb-mms-automation-agent
# Default-Start:     2 3 4 5
# Default-Stop:      0 1 6
# Short-Description: Disable Linux transparent huge pages
# Description:       Disable Linux transparent huge pages, to improve
#                    database performance.
### END INIT INFO

case $1 in
  start)
    if [ -d /sys/kernel/mm/transparent_hugepage ]; then
      thp_path=/sys/kernel/mm/transparent_hugepage
    elif [ -d /sys/kernel/mm/redhat_transparent_hugepage ]; then
      thp_path=/sys/kernel/mm/redhat_transparent_hugepage
    else
      return 0
    fi

    echo 'never' > ${thp_path}/enabled
    echo 'never' > ${thp_path}/defrag

    unset thp_path
    ;;
esac

修改权限并执行

sudo chmod 755 /etc/init.d/disable-transparent-hugepages
sudo /etc/init.d/disable-transparent-hugepages start

修改ulimit设置

ulimit -a

可以看到系统ulimit设置值,需要修改打开文件数和用户最大进程数,需要修改更大:

sudo vim /etc/security/limits.d/99-mongodb-nproc.conf

内容如下:

mongod soft nofile 64000  
mongod hard nofile 64000  
mongod soft nproc 524288 
mongod hard nproc 524288

其中分为soft配置和hard配置,保证soft<=hard;nofile是打开文件数,nproc是进程数,还需要参考/etc/sysctl.conf中的数据。

启动mongodb

sudo service mongod start

尝试登录:

mongo

如果没有提示任何WARNING信息说明以上配置参数是符合mongodb建议值了,enjoy!

由于本人是在虚拟机上测试就使用了root账户来安装mongoDB,如果在生产环境,请创建新的帐号和组:mongodb。

安装PHP的MongoDB扩展

访问:https://pecl.php.net/package/mongo

wget https://pecl.php.net/get/mongo-1.6.13.tgz
cd mongodb-1.1.9
/usr/local/php/bin/phpize
./configure --with-php-config=/usr/local/php/bin/php-config
make && make install

安装完成后,在php.ini中增加extension=mongodb.so并保存,重启php-fpm即可。

phpinfo打印出的扩展结果,证明扩展已经安装成功了。

写测试程序

在写测试程序之前,你首选需要在MongoDB中创建几条测试数据。具体创建方法可以参考我写的《MongoDB命令大全》详细介绍了常用的MongoDB的使用方法。

江边望海创建了一个db叫demo,集合叫teams里面有一套记录。

如上图:创建的测试数据

在你的web服务器(我的是nginx)的根目录创建一个php文件,粘贴下面代码:

<?php
$client = new MongoClient('mongodb://mongoadmin:mongoadmin@192.168.8.234:27017');
$db = $client->selectDB('demo');
$collection = $db->selectCollection('teams');
$cursor = $collection->findOne(array('_id' => new MongoId('582d5fa021b8cf1a733d7344')));
var_dump($cursor);

因为,我的mongoDB开启了授权访问。所以,需要在链接的填入用户名和密码。

如上图:可以从Collection中取出数据了。

参考链接:

http://litaook.com/blog/2016/01/22/install-mongodb-on-centos/

© 著作权归作者所有

共有 人打赏支持
江边望海
粉丝 28
博文 112
码字总数 57841
作品 3
郑州
技术主管
私信 提问
分布式缓存MongoDB+CentOS安装指南(阿里云)

在之前的文章介绍过了分布式缓存利器系列文章,进介绍另外一种NoSQL,它也是分布式缓存中间件--MongoDB。此文根据MongoDB官方网站安装指南简化而来,并且加入了自己的一些见解,就是为了使读...

landy8530
09/03
0
0
Percona Server for MongoDB 3.4.14-2.12 现已发布

Percona 宣布发布 Percona Server for MongoDB 3.4.14-2.12。Percona Server for MongoDB 是一款增强型,开放源代码且高度可扩展的数据库,它是MongoDB 3.2社区版的完全兼容的替代产品。它支...

周其
04/14
595
3
Linux中安装MongoDB(2015-11-03 00:51:24)

背景:之前有过一次试过安装MongoDB,但是网上说的方法各种各样,再加上虚拟机有问题,所以就导致没安装成功,今天在群里面提问,经过一哥们的提醒,告诉我直接上官网,按照官网上的安装方法...

Dreyer
2015/11/03
0
0
Percona Server for MongoDB 3.2.19-3.10 发布

Percona 宣布发布 Percona Server for MongoDB 3.2.19-3.10。Percona Server for MongoDB 是一款增强型,开放源代码且高度可扩展的数据库,它是MongoDB 3.2社区版的完全兼容的替代产品。它支...

周其
03/17
458
3
MongoDB Windows环境安装及配置

1.第一步:下载合适的安装包,目前的最新版本为2.6,网址为:http://www.mongodb.org/downloads。 安装包有zip和msi两种格式,msi安装时不让选择安装路径,默认安装到C:Program FilesMongoD...

zero2hero
2014/08/18
0
0

没有更多内容

加载失败,请刷新页面

加载更多

关于ComponentOne For WinForm 的全新控件 – DataFilter数据切片器(Beta)

概述 数据切片器在电子商务网站上很常见 - 它们可以帮助用户快速过滤所选商品,并且所有过滤选项都可以在一个地方使用,通常包含核心控件类型为:清单,范围栏和单选按钮等。在ComponentOne ...

葡萄城技术团队
15分钟前
1
0
Spring Data JPA 常见异常

异常一: Caused by: org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'userRepository': Invocation of init method failed; nested exception i......

小99
15分钟前
1
0
聊聊flink的EventTime

序 本文主要研究一下flink的EventTime SourceFunction flink-streaming-java_2.11-1.7.0-sources.jar!/org/apache/flink/streaming/api/functions/source/SourceFunction.java /** * Inte......

go4it
28分钟前
1
0
如何解决 homebrew 更新慢的问题

之前一直困扰于 Homebrew 的更新速度,曾试过修改更新源(清华、中科大等)的方式,但是并没什么卵用;也试过设置 curl 代理的方式,但是 brew 走的好像不是 curl 的方式,所以也没用。 通过...

whoru
32分钟前
4
0
TiDB EcoSystem Tools 原理解读系列(二)TiDB-Lightning Toolset 介绍

简介 TiDB-Lightning Toolset 是一套快速全量导入 SQL dump 文件到 TiDB 集群的工具集,自 2.1.0 版本起随 TiDB 发布,速度可达到传统执行 SQL 导入方式的至少 3 倍、大约每小时 100 GB,适合...

TiDB
34分钟前
2
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部