mongo学习整理
mongo做为NOSQL家族中一员,被广泛使用以及应用到生产环境中,有其出色的性能。关系型数据库(RDBMS )在互联网中依然是不可替代的一部分,mongo基于NOSQL的特性,在程序中RDBMS不适用或性能不高,操作不便,以及缺陷的领域发挥重要的作用。
RDBMS基于ACID准则设计:
ACID,指数据库事务正确执行的四个基本要素的缩写。包含:原子性(Atomicity)、一致性(Consistency)、隔离性(Isolation)、持久性(Durability)。一个支持事务(Transaction)的数据库,必需要具有这四种特性,否则在事务过程(Transaction processing)当中无法保证数据的正确性,交易过程极可能达不到交易方的要求。
NOSQL基于BASE思想CAP定理设计:
(1)Basically Available:基本可用;
(2)Soft-state:软状态/柔性事务,即状态可以有一段时间的不同步;
(3)Eventual consistency:最终一致性;
CAP定理,指的是在一个分布式系统中, Consistency(一致性)、 Availability(可用性)、Partition tolerance(分区容错性),三者不可得兼
mongo不支持事物操作,需要事物情况需要程序模拟或者用RDBMS型数据库替代。
mongo支持单document基本操作的原子性。批量操作是非原子性的。
mongo基本操作查阅help。
下面讲一下mongo的主从、集群
mongo有master-slave模式 replica-set模式 share分片模式
官网推荐用replica-set模式代替master-slave模式;
1 mongo master-slave模式
主从模式:一个主服务,1-N个从服务 主服务有读写的权限,从服务可依据情况配置做可读或只做数据冗余。该模式下不具备故障转移的功能,当主服务器故障时,从服务器不具备写的功能,服务功能部分失效。
主服务器配置
fork=true
logpath=/var/log/mongodb.log
logappend=true
port=10000
journal=true
dbpath=/data/mongo/master
master=true
从服务器配置
fork=true
logpath=/var/log/mongodb.log
logappend=true
port=10001
journal=true
dbpath=/data/mongo/slave
slave=true
source=127.0.0.1:10000
依次启动服务器即可实现主从配置。若从服务器不可读,可在从服务器执行db.setSlaveOk()
2 replica-set(副本集)模式:该模式由两个以上服务器+arbiter组成。该模式下,会从N个正常服务中选出1个作为主服务,其他为secondary服务器,arbiter仲裁在主服务器故障时辅助选出新的主服务器,实现故障转移。
服务器配置:
# 0
fork=true
logpath=/var/log/mongodb.log
logappend=true
port=10010
journal=true
dbpath=/data/mongo/replica/arbiter
# 1
replSet=rs0
fork=true
logpath=/var/log/mongodb.log
logappend=true
port=10011
journal=true
dbpath=/data/mongo/replica/1
replSet=rs0
# 2
fork=true
logpath=/var/log/mongodb.log
logappend=true
port=10012
journal=true
dbpath=/data/mongo/replica/2
replSet=rs0
配置了三个服务器 依次启动
var replicaSetConfig = {
_id: "rs0",
members: [
{ _id: 0,
host: 'localhost:10012',
},
{ _id: 1,
host: 'localhost:10011'
},
{ _id: 2,
host: 'localhost:10010',
arbiterOnly: true
}
]
}
rs.initiate(replicaSetConfig)配置副本集。
3 分片模式
其实分片是建立在其他模式上。
# config
fork=true
logpath=/var/log/mongodb.log
logappend=true
port=3000
journal=true
dbpath=/data/mongo/config
# share路由
fork=true
logpath=/var/log/mongodb.log
logappend=true
port=3001
configdb=localhost:3000
mongos -f share路由.conf
进入mongos配置分片
sh.addShard( "rs1/mongodb0.example.net:27017" )
sh.addShard( "mongodb0.example.net:27017" )
sh.enableSharding(dbname)
sh.shardCollection("records.people", { "zipcode": 1, "name": 1 } )
sh.shardCollection("people.addresses", { "state": 1, "_id": 1 } )
sh.shardCollection("assets.chairs", { "type": 1, "_id": 1 } )
sh.shardCollection("events.alerts", { "_id": "hashed" } )
写的好乱!
mongo学习整理的更多相关文章
- js数组学习整理
原文地址:js数组学习整理 常用的js数组操作方法及原理 1.声明数组的方式 var colors = new Array();//空的数组 var colors = new Array(3); // ...
- TweenMax学习整理--特有属性
TweenMax学习整理--特有属性 构造函数:TweenMax(target:Object, duration:Number, vars:Object) target:Object -- 需要缓 ...
- HttpClient学习整理
HttpClient简介HttpClient 功能介绍 1. 读取网页(HTTP/HTTPS)内容 2.使用POST方式提交数据(httpClient3) 3. 处理页面重定向 ...
- !!对python列表学习整理列表及数组详细介绍
1.Python的数组分三种类型:(详细见 http://blog.sina.com.cn/s/blog_6b783cbd0100q2ba.html) (1) list 普通的链表,初始化后可以通过特 ...
- Java设计模式(学习整理)---命令模式
设计模式之Command(学习整理) 1.Command定义 不少Command模式的代码都是针对图形界面的,它实际就是菜单命令,我们在一个下拉菜单选择一个命令时,然后会执行一些动作. 将这些命令封装 ...
- Wix学习整理(5)——安装时填写注册表
原文:Wix学习整理(5)--安装时填写注册表 一 Microsoft操作系统的注册表 什么是注册表? 注册表是Mircrosoft Windows中的一个重要的数据库,用于存储系统和应用程序的设置信 ...
- Wix学习整理(6)——安装快捷方式
原文:Wix学习整理(6)--安装快捷方式 一 为HelloWorld案例添加安装快捷方式 通常我们安装一个应用软件的时候,都喜欢在桌面或开始菜单中添加快捷方式以便我们快速访问.现在我们就在上篇添加注 ...
- Wix学习整理(7)——在开始菜单中为HelloWorld添加卸载快捷方式
原文:Wix学习整理(7)--在开始菜单中为HelloWorld添加卸载快捷方式 通过前面的几篇随笔,我们已经给我们的HelloWorld提供了填写注册表信息,以及开始菜单快捷方式和桌面快捷方式.这些 ...
- Wix学习整理(4)——关于WiX文件格式和案例HelloWorld的分析
原文:Wix学习整理(4)--关于WiX文件格式和案例HelloWorld的分析 关于WiX文件格式 .wxs是WiX的源文件扩展名..wxs文件以类XML文件的格式来指定了要构造Windows In ...
随机推荐
- angular2 学习笔记 (Typescript)
1.接口奇葩验证 interface Abc { name : string } function abc(obj : Abc) { } let ttc = { name: "adad&qu ...
- 突然间,对JAVA也找到点感觉了。
书上没有那段代码,我自己修修补补弄完全了呢.... 就是感觉体系有点宏大,不要急,慢慢玩~!~~ 这个世界很精彩哟~~: QuizCard.java package QuizCard.sky.com; ...
- 破解简单Mifare射频卡密钥杂记
先要了解一点大学城浴卡用的是什么卡,经查证是Mifare S50卡,也有叫ISO14443A的(协议名).本来想看看大学城浴卡有没有安全漏洞,没想到浴卡公司在安全性上几乎是蔑视我们大学生的智商,虽然被 ...
- Codeforces Round #312 (Div. 2)小结
爆炸了爆炸了...E题一个裸线段树没打完,A题wa了半天...... 爆炸了爆炸了....爆炸了爆炸了....rank270+滚粗 以后还是得多做模拟题...
- COJ 3018 求1~n之间的素数
求1~n之间的素数 难度级别:A: 运行时间限制:1000ms: 运行空间限制:256000KB: 代码长度限制:2000000B 试题描述 素数是大于1,且除1和本身以外不能被其他整数所整除的数. ...
- 构建你的第一个App
Building Your First App 原文链接:http://developer.android.com/training/basics/firstapp/index.html 译文链接1: ...
- poj 2246 (zoj 1094)
http://acm.zju.edu.cn/onlinejudge/showProblem.do?problemCode=1094 ZOJ Problem Set - 1094 Matrix Chai ...
- STL_iterator迭代器(2)——几种迭代器对象的用法
要学会使用迭代器和容器以及算法,需要学习下面的新技术. 一.流和迭代器 本书的很多例子程序使用I/O流语句来读写数据.例如: int value; cout << "Enter ...
- Matlab绘制三维图形以及提示框
1.首先,在编辑区输入如下代码 >> [x,y] = meshgrid([-100,0.1,100]); >> z = sqrt(x.^2 + y.^2); >> ...
- 使用PHPExcel导出数据
最近要求做增加客流数据等导出为Excel的功能,phpExcel包功能强大,根据实际需求,我只学习了简单的功能. 安装PHPExcel 在composer.json中添加: "require ...