热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

安装MongoDB配置ReplicaSet

MongoDB的环境主要包括StandAlone,Replication和Sharding。因为数据量和机器量的原因,项目最终用了一个Primary,一个Secondary

MongoDB的环境主要包括StandAlone,Replication和Sharding。因为数据量和机器量的原因,项目最终用了一个Primary,一个Secondary

MongoDB的环境主要包括StandAlone,Replication和Sharding。

  • StandAlone:单机环境,一般开发测试的时候用。
  • Replication:主从结构,一个Primary,多个Secondary,可能会有Arbitry。
  • Sharding:share nothing的结构,每台机器只存一部分数据。mongod服务器存数据,mongos服务器负责路由读写请求,,元数据存在config数据库中。
  • 因为数据量和机器量的原因,项目最终用了一个Primary,一个Secondary,一个Arbitry。我自己的开发环境是Ubuntu,测试环境是CentOS。安装的是64位的MongoDB。

    Ubuntu上的安装

    sudo apt-get install mongodb-10gen

    CentOS上的安装

    配置yum源,创建文件:/etc/yum.repos.d/mongodb.repo

    [mongodb] name=MongoDB Repository baseurl=http://downloads-distro.mongodb.org/repo/RedHat/os/x86_64/ gpgcheck=0 enabled=1

    安装命令:

    yum install mongo-10gen mongo-10gen-server

    配置

    每台机器上面的配置文件/etc/mongod.conf修改成下面的:

    #数据库文件所在位置(默认) dbpath=/var/lib/mongo #日志所在位置(默认) logpath=/var/log/mongo/mongod.log #pid所在位置(默认) pidfilepath = /var/run/mongodb/mongod.pid #keyFile所在位置,生成方式在后面(添加) keyFile=/var/lib/mongo/key #端口(默认) port=27017 #每次启动后日志追加在后面,不会新建日志文件(默认) logappend=true #用deamon方式启动(添加) fork=true #打开操作日志,用于故障恢复和持久化(默认) journal=true #replica set的名字(添加) replSet=test-set

    在每台机器上运行:

    sudo mongod -f /etc/mongod.conf

    我的环境里面,Primary ip: 192.168.1.1,Secondary ip: 192.168.1.2,Arbitary ip: 192.168.1.3。在单机上可以将多个mongodb设置成不同端口,我测试了一下也是可以的。

    在Primary上运行“mongo”,打开命令行,设置Replica Set:

    rs.initiate( {: , : [ {: : }, {: : }, {: : , : true} ] }); { : "ok" : 1 }

    历史成功后需要等一段时间,他会选举Primary,然后查看Replica Set的状态:

    test-set:PRIMARY> rs.status() { : "test-set", : ISODate(), : 7, : [ { : 1, : , : 1, : 1, : , : 4086, : Timestamp(1392972480, 1), : ISODate(), : ISODate(), : ISODate(), : 0 }, { : 2, : , : 1, : 2, : , : 3997, : Timestamp(1392972480, 1), : ISODate(), : ISODate(), : ISODate(), : 0, : }, { : 3, : , : 1, : 7, : , : 5781, : true } ], : 1 }

    这样整个replica set就配置成功了,还是比较简单的。

    MongoDB 的详细介绍:请点这里
    MongoDB 的下载地址:请点这里

    相关阅读:

    MongoDB备份与恢复

    CentOS编译安装MongoDB

    CentOS 编译安装 MongoDB与mongoDB的php扩展

    CentOS 6 使用 yum 安装MongoDB及服务器端配置

    Ubuntu 13.04下安装MongoDB2.4.3

    如何在MongoDB中建立新数据库和集合

    MongoDB入门必读(概念与实战并重)

    《MongoDB 权威指南》(MongoDB: The Definitive Guide)英文文字版[PDF]


    推荐阅读
    • Allegro总结:1.防焊层(SolderMask):又称绿油层,PCB非布线层,用于制成丝网印板,将不需要焊接的地方涂上防焊剂.在防焊层上预留的焊盘大小要比实际的焊盘大一些,其差值一般 ... [详细]
    • 本文介绍了Linux系统中正则表达式的基础知识,包括正则表达式的简介、字符分类、普通字符和元字符的区别,以及在学习过程中需要注意的事项。同时提醒读者要注意正则表达式与通配符的区别,并给出了使用正则表达式时的一些建议。本文适合初学者了解Linux系统中的正则表达式,并提供了学习的参考资料。 ... [详细]
    • Ubuntu 9.04中安装谷歌Chromium浏览器及使用体验[图文]
      nsitionalENhttp:www.w3.orgTRxhtml1DTDxhtml1-transitional.dtd ... [详细]
    • Linux如何安装Mongodb的详细步骤和注意事项
      本文介绍了Linux如何安装Mongodb的详细步骤和注意事项,同时介绍了Mongodb的特点和优势。Mongodb是一个开源的数据库,适用于各种规模的企业和各类应用程序。它具有灵活的数据模式和高性能的数据读写操作,能够提高企业的敏捷性和可扩展性。文章还提供了Mongodb的下载安装包地址。 ... [详细]
    • CentOS 7部署KVM虚拟化环境之一架构介绍
      本文介绍了CentOS 7部署KVM虚拟化环境的架构,详细解释了虚拟化技术的概念和原理,包括全虚拟化和半虚拟化。同时介绍了虚拟机的概念和虚拟化软件的作用。 ... [详细]
    • MySQL语句大全:创建、授权、查询、修改等【MySQL】的使用方法详解
      本文详细介绍了MySQL语句的使用方法,包括创建用户、授权、查询、修改等操作。通过连接MySQL数据库,可以使用命令创建用户,并指定该用户在哪个主机上可以登录。同时,还可以设置用户的登录密码。通过本文,您可以全面了解MySQL语句的使用方法。 ... [详细]
    • 分享css中提升优先级属性!important的用法总结
      web前端|css教程css!importantweb前端-css教程本文分享css中提升优先级属性!important的用法总结微信门店展示源码,vscode如何管理站点,ubu ... [详细]
    • 2016 linux发行版排行_灵越7590 安装 linux (manjarognome)
      RT之前做了一次灵越7590黑苹果炒作业的文章,希望能够分享给更多不想折腾的人。kawauso:教你如何给灵越7590黑苹果抄作业​zhuanlan.z ... [详细]
    • 本文介绍了在Web应用系统中,数据库性能是导致系统性能瓶颈最主要的原因之一,尤其是在大规模系统中,数据库集群已经成为必备的配置之一。文章详细介绍了主从数据库架构的好处和实验环境的搭建方法,包括主数据库的配置文件修改和设置需要同步的数据库等内容。MySQL的主从复制功能在国内外大型网站架构体系中被广泛采用,本文总结了作者在实际的Web项目中的实践经验。 ... [详细]
    • LVS实现负载均衡的原理LVS负载均衡负载均衡集群是LoadBalance集群。是一种将网络上的访问流量分布于各个节点,以降低服务器压力,更好的向客户端 ... [详细]
    • 本文介绍了在Ubuntu 11.10 x64环境下安装Android开发环境的步骤,并提供了解决常见问题的方法。其中包括安装Eclipse的ADT插件、解决缺少GEF插件的问题以及解决无法找到'userdata.img'文件的问题。此外,还提供了相关插件和系统镜像的下载链接。 ... [详细]
    • Centos7.6安装Gitlab教程及注意事项
      本文介绍了在Centos7.6系统下安装Gitlab的详细教程,并提供了一些注意事项。教程包括查看系统版本、安装必要的软件包、配置防火墙等步骤。同时,还强调了使用阿里云服务器时的特殊配置需求,以及建议至少4GB的可用RAM来运行GitLab。 ... [详细]
    • 如何使用Java获取服务器硬件信息和磁盘负载率
      本文介绍了使用Java编程语言获取服务器硬件信息和磁盘负载率的方法。首先在远程服务器上搭建一个支持服务端语言的HTTP服务,并获取服务器的磁盘信息,并将结果输出。然后在本地使用JS编写一个AJAX脚本,远程请求服务端的程序,得到结果并展示给用户。其中还介绍了如何提取硬盘序列号的方法。 ... [详细]
    • Centos下安装memcached+memcached教程
      本文介绍了在Centos下安装memcached和使用memcached的教程,详细解释了memcached的工作原理,包括缓存数据和对象、减少数据库读取次数、提高网站速度等。同时,还对memcached的快速和高效率进行了解释,与传统的文件型数据库相比,memcached作为一个内存型数据库,具有更高的读取速度。 ... [详细]
    • Linux下安装免费杀毒软件ClamAV及使用方法
      本文介绍了在Linux系统下安装免费杀毒软件ClamAV的方法,并提供了使用该软件更新病毒库和进行病毒扫描的指令参数。同时还提供了官方安装文档和下载地址。 ... [详细]
    author-avatar
    mobiledu2502883017
    这个家伙很懒,什么也没留下!
    PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
    Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有