MongoDB 驱动以及分布式集群读取优先级设置
1 MongoDB C 驱动编译安装
3 使用C驱动
3 遇到的坑


mongoc_read_prefs_t* read_prefs = mongoc_read_prefs_new(MONGOC_READ_NEAREST);
bson_t* tag = bson_new();
mongoc_read_prefs_add_tag(read_prefs, tag);
bson_destroy(tag);
mongoc_cursor_t* cursor = mongoc_collection_find(collection, MONGOC_QUERY_NONE, , , , query, NULL, read_prefs);
bson_t* tag = bson_new();
BSON_APPEND_UTF8(tag, "location", "bj");
mongoc_read_prefs_add_tag(read_prefs, tag);
bson_destroy(tag);
bson_t* tag = bson_new();
BSON_APPEND_UTF8(tag, "location", "bj");
mongoc_read_prefs_add_tag(read_prefs, tag);
mongoc_read_prefs_add_tag(read_prefs, NULL);
bson_destroy(tag);
4 其它驱动
#!/home/work/bin/python
# test find with tag_set
# cswuyg @ 2014.7.18
# install pymongo pre. import pymongo
import time REMOTE_ADDRESS = "xxxxhost"
REMOTE_PORT = 27030
def _test_find():
f_w = open("test", 'w')
#client = pymongo.MongoClient(REMOTE_ADDRESS, 27030, readPreference='nearest')
rpre = pymongo.read_preferences.Secondary(tag_sets = [{'location': 'gz'}])
client = pymongo.MongoClient(REMOTE_ADDRESS, REMOTE_PORT, read_preference=rpre) # 注意这里的read_preference
s = time.time()
docs = client.myapp.myuser.find({'name': 'cswuyg'})
with open('tmp.txt', 'w') as f_w:
for item in docs:
f_w.write(str(item))
f_w.write('\n') e = time.time()
print(e - s) if __name__ == "__main__":
_test_find()
/*
* 测试 mongodb 驱动 耗时
* cswuyg @ 2015.12.29
*/
"use strict";
var mongodb = require('mongodb');
var assert = require('assert');
var fs = require('fs');
var url = 'mongodb://xxxhost:27030/myapp?w=1&readPreference=nearest&readPreferenceTags=location:bj'; //在uri上设置读取优先级和tag var findDocuments = function(collection, callback) {
collection.find({'name': 'cswuyg'}).limit(1).toArray(function(err, docs) {
callback(docs);
});
} mongodb.MongoClient.connect(url, function(err, db) {
assert.equal(null, err);
console.log("Connected correctly to server");
var col = db.collection('myuser');
var s = new Date().getTime();
findDocuments(col, function(docs) {
var writerStream = fs.createWriteStream('tmp.txt');
writerStream.write(JSON.stringify(docs[0]), 'UTF8');
writerStream.end();
var e = new Date().getTime();
console.log(e - s);
});
});
/*
* * 测试 mongoose 耗时
* * cswuyg @ 2015.12.29
* */
"use strict"; var mongoose = require('mongoose');
var fs = require('fs');
var connect = mongoose.createConnection('mongodb://xxxhost:27030, yyyhost:27030/myapp', {mongos: true}); //注意mongos var schema = {name: {type: String}};
var colSchema = new mongoose.Schema(schema, {collection: 'myuser'});
var model = connect.model('myuser', colSchema); setTimeout(function() {
var s = new Date().getTime();
var query = new mongoose.Query({'name': 'cswuyg'}).read('n', [{location:'nj'}]); //Query层面设置读取优先级和tag
model.find(query).exec(function(err, doc) {
var writerStream = fs.createWriteStream('output.txt');
writerStream.write(doc.toString(), 'UTF8');
writerStream.end();
var e = new Date().getTime();
console.log(e - s);
}); }, 1000); setTimeout(function() {
var s = new Date().getTime();
var query = new mongoose.Query({'name': 'cswuyg'}).read('n', [{location:'nj'}]);
model.find(query).exec(function(err, doc) {
var writerStream = fs.createWriteStream('output.txt');
writerStream.write(doc.toString(), 'UTF8');
writerStream.end();
var e = new Date().getTime();
console.log(e - s);
}); }, 2000);
MongoDB 驱动以及分布式集群读取优先级设置的更多相关文章
- 2020重新出发,NOSQL,MongoDB分布式集群架构
MongoDB分布式集群架构 看到这里相信你已经掌握了 MongoDB 的大部分基本知识,现在在单机环境下操作 MongoDB 已经不存在问题,但是单机环境只适合学习和开发测试,在实际的生产环境中,M ...
- spring-session实现分布式集群session的共享
前言 HttpSession是通过Servlet容器创建和管理的,像Tomcat/Jetty都是保存在内存中的.但是我们把应用搭建成分布式的集群,然后利用LVS或Nginx做负载均衡,那么来自同一用户 ...
- spring-session实现分布式集群session的共享(转)
原文: https://www.cnblogs.com/youzhibing/p/7348337.html HttpSession是通过Servlet容器创建和管理的,像Tomcat/Jetty都是保 ...
- mongodb的分布式集群(2、副本集)
概述 副本集是主从复制的一种,是一种自带故障转移功能的主从复制.攻克了上述主从复制的缺点.实现主server发生问题后.不需人为介入.系统自己主动从新选举一个新的主server的功能. ...
- mongodb的分布式集群(4、分片和副本集的结合)
概述 前面3篇博客讲了mongodb的分布式和集群,当中第一种的主从复制我们差点儿不用,没有什么意义,剩下的两种,我们不论单独的使用哪一个.都会出现对应的问题.比較好的一种解决方式就是.分片和副本集的 ...
- mongodb分布式集群搭建手记
一.架构简介 目标单机搭建mongodb分布式集群(副本集 + 分片集群),演示mongodb分布式集群的安装部署.简单操作. 说明在同一个vm启动由两个分片组成的分布式集群,每个分片都是一个PSS( ...
- YCSB测试HBase远程完全分布式集群
写在前面 本文只讲一个很简单的问题,YCSB对HBase集群的测试.虽然网上有很多介绍YCSB测试HBase的文章,但都是针对本地HBase伪分布式集群的.大家都知道,稍微正式一些的压测都会要求测试客 ...
- MongoDB 3.0 常见集群的搭建(主从复制,副本集,分片....)
一.mongodb主从复制配置 主从复制是mongodb最常用的复制方式,也是一个简单的数据库同步备份的集群技术,这种方式很灵活.可用于备份,故障恢复,读扩展等. 最基本的设置方式就是建立一个主节 ...
- elasticsearch 口水篇(5)es分布式集群初探
es有很多特性,分布式.副本集.负载均衡.容灾等. 我们先搭建一个很简单的分布式集群(伪),在同一机器上配置三个es,配置分别如下: cluster.name: foxCluster node.nam ...
随机推荐
- 对魔兽世界、支付宝、Linux三类软件的简单分析
软工第一次作业: 软件有很多种,如工具类软件.游戏类软件.系统类软件,它们的运行方式也各种各样,如以单机方式运行.以网站方式运行或者以APP方式运行在手机端等,请选取三种软件,分析它们各自的特点. 这 ...
- windows 7系统下出现某盘回收站损坏解决办法
今天遇到一个从没有遇见的问题,就是领导说他的回收站损坏了,要我去看下,我一开始也没用辙,网上搜了很多,说在命令提示符里面修改,我试了不行,后来我这样做就好了:1.打开计算机 2.找到工具选项,单击选择 ...
- http错误码
2xx 成功 200 正常:请求已完成. 201 正常:紧接 POST 命令. 202 正常:已接受用于处理,但处理尚未完成. 203 正常:部分信息 - 返回的信息只是一部分. ...
- Xcode 8
(一)Xcode8去掉多余LOG 1.打开我们的项目,进入EditScheme 2.我们在Environment Variables中添加OS_ACTIVITY_MODE=disable
- 初窥Linux 之 我最常用的20条命令
魏公 SecureCRTuname -avisftppartition,fsshell kshell,bshelluser,groupIPTables文件数,内核参数tail,less/var/log ...
- Struts 2开发基本流程
Struts 2工作流程 Struts2是一个基于MVC设计模式的Web开发框架, 正如官网上介绍的那样: ApacheStruts 2 is an elegant, extensible frame ...
- 微信小程序-表单
wxml <view> 按钮: <button size="{{buttom.size}}" type="{{buttom.type}}" p ...
- SQL-Server使用点滴(二)
二,对象的建立和使用 1,了解MSSql的[系统表] 对于SQL-Server中的所有对象,包括数据库,数据表,记录,字段,触发器,索引,数据类型等元素,均有对应的系统表记性记录.系统表是禁止直接删改 ...
- Allegro 导入DXF文件,保留布好的线路信息
最近智能钥匙产品开发过程中,由于结构装配尺寸的偏差,需要对电路PCB外框OUTLINE进行缩小调整,并且USB插座定位孔改变. Allegro软件在线性绘制方面是有严重缺陷的,想绘制一个异形的板框比较 ...
- jq
1: http://jquery.cuishifeng.cn/index.html jquery 学习查询首页<br> 2: http://m.oschina.net/blog/75741 ...