Mongodb数据库学习系列————(一)Mongodb数据库主从复制的搭建

Mongodb数据库主从复制的搭建

Writeby:lipeng                                    date:2014-10-22

最近项目上用到了位置查询,在网上看到mongodb支持距离的查询,所以就学习了一下mongodb,在学习中总结了一下遇到的问题和解决的办法,以及mongodb的安装,主从复制,集群和在.NET应用程序中的操作,记录下来方便自己以后用得到,同时也希望能帮助那些初学mongodb的人,本人由于刚学mongodb,出现问题望大家提醒出来,相互学习,共同进步。

1.  准备

Windows操作系统的电脑一台,在E盘新建两个文件夹分别来存放主数据库和从数据库,主数据库中的配置文件如下:

其中port为端口,dbpath为数据库文件的存放位置,logpath围殴日志文件的存放位置

注意:master=true 表示为主服务器。

从服务器的配置文件如下:

其中Port为端口号,dbpath为数据库文件的存放位置,logpath围殴日志文件的存放位置

注意:slave=true 表示为主服务器。Source=127.0.0.1:27017 表示从哪个服务器同步数据库文件。

2.  具体实现

  1. 打开一个cmd命令操作,执行如下命令:

其中:--config 后面输入配置文件的位置,

启动成功后显示如下:

此时,主服务器已启动成功。

2.再次打开一个cmd操作程序,执行如下命令:

其中:--config 后面输入配置文件的位置

启动成功后显示如下:

此时从服务器已打开。

3.开主服务器的网页:http://localhost:28017/  ----注意端口号加1000如下:

可以看到:

3.打开从服务器的网页:http://localhost:13548/  ----注意端口号加1000如下:

可以看到:

3.测试

在主服务器的shell中输入如下指令:db.test.save({“11”,123})

在从服务器的shell中输入如下指令:db.test.find()结果如下:

测试结果表明主从复制已完成。

4.  遇到的问题及解决方案

  1. 启动mongodb的时间报错;can not read from mongdb.config。产生这个错误的原因有可能是配置文件的路径写的不正确或者配置文件的参数写的不正确。
  2. 报错如下:

产生这个错误的原因是因为开启的端口号已被占用,换一个端口即可正常启动。

时间: 2024-10-17 17:41:54

Mongodb数据库学习系列————(一)Mongodb数据库主从复制的搭建的相关文章

MongoDB入门学习(三):MongoDB的增删查改

对于我们这种菜鸟来说,最重要的不是数据库的管理,也不是数据库的性能,更不是数据库的扩展,而是怎么用好这款数据库,也就是一个数据库提供的最核心的功能,增删查改. 因为MongoDB存储数据都是以文档的模式,所以在操作它的数据时,也是以文档为单位的.那么我们实现增删查改也是以文档为基础,不知道文档是什么的同学可以看看上篇介绍的基本概念. 1.插入文档 向MongoDB集合中插入文档的基本方法是insert: 单个插入 > document = {key : value} > db.collecti

MongoDB入门学习(四):MongoDB的索引

上一篇讲到了MongoDB的基本操作增删查改,对于查询来说,必须按照我们的查询要求去集合中,并将查找到的结果返回,在这个过程中其实是对整个集合中每个文档进行了扫描,如果满足我们的要求就添加到结果集中最后返回.对于小集合来说,这个过程没什么,但是集合中数据很大的时候,进行表扫描是一个非常恐怖的事情,于是有了索引一说,索引是用来加速查询的,相当于书籍的目录,有了目录可以很精准的定位要查找内容的位置,从而减少无谓的查找. 1.索引的类型 创建索引可以是在单个字段上,也可以是在多个字段上,这个根据自己的

MongoDB入门学习(二):MongoDB的基本概念和数据类型

上一篇讲了MongoDB的安装和管理,其中涉及到了一些概念,数据结构还有一些API的调用,不知道的没关系,其实很简单,这篇会简单介绍一下. 1.文档 文档是MongoDB的核心概念,多个键值对有序的放在一起就是一个文档,文档是MongoDB存储数据最基本的数据结构.对MongoDB都是以文档的形式来操作的,使用了一种类似JSON的二进制BSON数据格式,对API的调用都是传的文档参数.每种编程语言都有标示文档的数据结构,比如java的map,lua的table,python的dict等等,但是都

【华为云技术分享】MongoDB经典故障系列一:数据库频繁启动失败怎么办?

MongoDB频繁启动失败怎么办?别慌,华为云数据库给您提供一个小妙招:一看报错日志探究竟,二查目录文件揪根因,三要认真仔细不犯小错,让您轻松搞定启动难题. 此外,华为云数据库特别推出了免费专区活动,MySQL与DDS免费试用2个月,更多活动详情请前往华为云官网——最新活动——新手福利——疫情专区——云数据库. 原文地址:https://www.cnblogs.com/huaweicloud/p/12384889.html

[原]SQLite的学习系列之获取数据库版本

最先了解到SQLite是基于其作为移动客户端数据存储平台,以下是其官网(https://www.sqlite.org/)关于SQLite的一段介绍: SQLite是遵守ACID的轻型数据库引擎,它包含在一个相对小的C库中.它是D.RichardHipp创建的公有领域项目.SQLite第一个Alpha版本诞生于2000年5月,至今已经有16个年头,当前版本为3.12.2..不像常见的客户端/服务器结构范例,SQLite引擎不是个程序与之通信的独立进程,而是连接到程序中成为它的一个主要部分.所以主要

[原]SQLite的学习系列之获取数据库版本二

本系列文章主要是使用C++语言来调用其API,达到管中窥豹的目的.另外本文使用的开发环境为mac + clion,并且基于SQLite 3.7.14来进行开发. 一.去下载sqlite-amalgamation-3071400.zip,然后解压到文件夹(其结构目录树如下): . ├── shell.c ├── sqlite3.c ├── sqlite3.h └── sqlite3ext.h 二.新建一个sql_tutorial的工程,景sqlite3.c和sqlite3.h文件拷贝到sql_sr

MongoDB入门学习(一):MongoDB的安装和管理

以前用MySQL数据库,整天都是写大堆大堆的SQL语句,要记住这些SQL关键字都要花好几天时间,写的蛋都爆了,当接触到MongoDB的时候,发现不用写SQL,瞬间觉得高大上,瞬间产生了学习使用它的冲动. 1.MongoDB简介 MongoDB是一种强大,灵活,可扩展的数据存储方式.它扩展了关系型数据库的众多有用功能,如辅助索引,范围查询和排序.MongoDB的功能非常丰富,比如内置的对MapReduce式聚合的支持,以及对地理空间索引的支持.还有很多很多的特点... 对于入门级别的人来说,上面说

时序数据库连载系列:时序数据库那些事

正如<银翼杀手>中那句在影史流传经典的台词:"I've seen things you people wouldn't believe... All those ... moments will be lost in time, like tears...in rain." 时间浩瀚的人类历史长河中总是一个耀眼的词汇,当科技的年轮划到数据时代,时间与数据库碰到一起,把数据库内建时间属性后,产生了时序数据库.时序数据库是一种带有时间戳业务属性的垂直型数据库.自从2014年开始

hibernate学习系列-----(1)开发环境搭建

其实一两个月前就在了解hibernate方面的知识了,但一直以来,都没有好好的总结,而且一直使用的是myeclipse,感觉有些傻瓜式的操作就可以搭建起hibernate的开发环境,但这样一点都不好,没有理解到hibernate到底是怎么配置的,所以你今天特使用Eclipse来一步一步搭建hibernate的开发环境,下面,正式进入正题. 新建一个web项目,名字就随便吧,你喜欢什么名字就什么吧,这是我的截图. 引入hibernate的依赖jar包,我使用的是hibernate-release-