mongodb cxx driver学习
mongodb学习
概念
- oplog 主节点的操作记录,幂等性
- mongod mongo后台进程
- secondary节点 副本集中的非主结点
集群
- 功能
- 数据冗余
- 读写分离?
- 缺点
- 容错性差
副本集
- 概念
- 一组有相同数据的mongodb实例,只有主实例执行写操作,其它实例保持同步;主可读写,其它节点只可读
- 功能
- 自动容错(auto-failover)
- 自动恢复(auto-recovery)
- 读写分离
- connection string的options里添加readPreference=secondaryPreferred
- 数据冗余
- 缺点
- 待补充
- 注意事项
- 如果使用当前主节点地址建立连接,当当前主节点失效(降级为secondary节点),客户端将无法执行写操作
- 使用 副本集方式 连接副本集
- connection string的options里添加replicaSet=xxx
- replicaSet参数指定,要连接的是一个副本集,但只提供了一个在这个副本集中的ip:host,是什么行为?
- 如果不传这个参数,至少提供了两个在这个副本集中的ip:host,通过mongo driver可以检测是否为副本集
- 如果不传这个参数,只提供了一个在这个副本集中的ip:host,mongo driver只会连接这一个ip:host
- driver建立连接的过程
- 参考了下面文献中stackoverflow.com的一个提问,但没有分析过cxx driver代码和验证
- 如果seed list中有多个ip:host,driver会检测使用哪种连接方式(replicaSet还是sharding)
- 如果检测到是replicaset,driver会通过seed list中的结点找到主节点
- 然后driver更新replicaset中的结点,并动态维持最新的状态
安装
mongo-c-driver
- 是安装mongo-cxx-driver的基础
- 根据使用的mongo-cxx-driver,确定mongo-c-driver版本,可参考mongo-cxx-driver发布页面
- 两个库都使用cmake编译,
yum install cmake3
cmake3 -DENABLE_AUTOMATIC_INIT_AND_CLEANUP=OFF -DCMAKE_BUILD_TYPE=Release ..
mongo-cxx-driver
- 注意与mongo-c-driver相匹配
cmake3 -DCMAKE_BUILD_TYPE=Release -DBSONCXX_POLY_USE_BOOST=1 -DCMAKE_INSTALL_PREFIX=/usr/local ..
参考
API学习
MONGO C API
使用文档
连接池参数
MONGO CXX API
概念
增删改查
- insert 向集合中增加一个文档
- remove 删除文档
- update 更新(修改)某些文档
- 文档替换
- 文档修改器,只修改文档某个部分
- find 返回集合中所有文档
- findOne 返回集合中的某一个文档
tutorial
- 建立连接
- mongocxx::instance
- mongocxx::uri
- mongocxx::client
- 访问数据库、集合
- 使用 []操作符
- database()方法、collection()方法
- 访问文档中的fields
- 使用 []操作符
- 返回的是bsoncxx::document::element
- 如何判断是否返回有效值?(有这个fields)
- 由element转换为代码中使用的各种类型?
bsoncxx::document::element element = view["name"];
if(element.type() != bsoncxx::type::k_utf8) {
// Error
}
std::string name = element.get_utf8().value.to_string();
bsoncxx::type中规定的类型
- k_utf8 string类型?
- 待补充
- 待补充
- 待补充
创建BSON文档的方法
- bsoncxx::builder::stream
- bsoncxx::builder::basic
- one-off builder functions
using bsoncxx::builder::basic::kvp;
// { "hello": "world" }
bsoncxx::document::value document = bsoncxx::builder::basic::make_document(kvp("hello", "world"));
- 文档的两种存在状态
- bsoncxx::document::value
- bsoncxx::document::view
- view转换成string
stdx::string_view view = e.get_utf8().value;
string name = view.to_string();
- 在集合中查询文档
- find
- 返回mongocxx::cursor
- find_one
- 返回std::optionalbsoncxx::document::value
- 因此判断是否存在这个field只需像指针是否为空那样
- 将返回的结果转换成json, bsoncxx::to_json()
- find
- 插入、更新、删除文档
- insert_many insert_one
- update_many update_one
- delete_many delete_one
- 多线程与连接池
- 每个线程都有独立的client及其子类
参考文献
http://mongocxx.org/
https://stackoverflow.com/questions/35920013/new-c-mongo-driver-how-to-see-type-and-how-to-get-string-value
Mongodb主从复制/ 副本集/分片集群介绍
Connection String URI
https://docs.mongodb.com/ecosystem/drivers/
[MongoDB Connection String to Replica Set](MongoDB Connection String to Replica Set)
https://mongodb-documentation.readthedocs.io/en/latest/reference/connection-string.html#uri.replicaSet
https://stackoverflow.com/questions/23958759/mongodb-connection-string-to-replica-set
mongodb cxx driver学习的更多相关文章
- MongoDB数据库CXX Driver编译
最近项目需要,想要测试下MongoDB读写大量小图片的速度(单纯文件系统io效率比较低,想试试NoSQL能不能提速), 因为使用C++开发,所以使用MongoDB的CXX驱动,需要自己编译,下面记录整 ...
- mongodb C++ Driver安装
前言 mongocxx官网地址 http://mongocxx.org/?jmp=docs 本文的安装版本是:mongocxx-r3.2.0.tar.gz . 参考文档安装过程http://mongo ...
- MongoDB Java Driver操作指南
MongoDB为Java提供了非常丰富的API操作,相比关系型数据库,这种NoSQL本身的数据也有点面向对象的意思,所以对于Java来说,Mongo的数据结构更加友好. MongoDB在今年做了一次重 ...
- MongoDB C Driver使用教程
MongoDB C Driver使用教程 转载请注明出处http://www.cnblogs.com/oloroso/ 本指南提供简介 MongoDB C 驱动程序. 在 C API 的详细信息,请参 ...
- windows平台下安装、编译、使用mongodb C++ driver
本博客将记录在Win8.1 ,VS2013环境下编译.配置mongodb C++ driver的流程. 1.下载预备 下载Boost:http://sourceforge.net/projects/b ...
- Ignoring Extra Elements in mongoDB C# Driver
MongoDB删除字段后会报错: Element ... does not match any field or property of class Customer. 需要在实体类增加 [BsonI ...
- mongodb .net driver
1.介绍 The official MongoDB .NET Driver provides asynchronous interaction with MongoDB. Powering the d ...
- Mongodb Java Driver 参数配置解析
要正确使用Mongodb Java Driver,MongoClientOptions参数配置对数据库访问的并发性能影响极大. connectionsPerHost:与目标数据库能够建立的最大conn ...
- mongodb c++ driver(2.53)windows编译
编译环境: (1) 下载python2.7, 使用x86_32位,因为scons只有32位安装包可用: (2) 下载scons2.3.0,The current production release ...
随机推荐
- sCMOS相机调试参考资料
sCMOS相机调试参考资料 实验室调试sCMOS传感器,特此记录一下网上搜集的资料. 来自比利时的AXIOM开源相机公司:https://wiki.apertus.org/index.php/Sens ...
- Git全面应用
Git是一个免费的开源分布式版本控制系统,旨在快速高效地处理从小型到大型项目的所有事务. Git易于学习,占地面积小,具有闪电般快速的性能. 它超越了Subversion,CVS,Perforce和C ...
- 拖拽 ‘vue-grid-layout’ 插件了解下
我接触到vue-grid-layout是通过我们公司的项目,感觉还是比较简单上手的,大概看了有1个小时吧,我是个行动派,就是觉得实践出真知,但是记性也不太好,有时候自己踩过的坑会忘记,会改但是会忘记原 ...
- redis 安装和配置
准备条件:1>确保所安装的环境能够访问网络,2>环境中拥有gcc\g++.make.tar等工具3>以root身份登录安装过程:1>输入命令:wget http://downl ...
- 佳鑫:信息流广告CTR一样高,哪条文案转化率更好?
在优化信息流广告的过程中,你有没有遇到这样的帐户? 投了几个AB方案,点击率好不容易上去了,但转化率还是有的高.有的低! 这儿就有这么一个为难的案例: 一个广告主计划向有意愿在北京预订酒店的用户投放信 ...
- 学会使用box-sizing布局
盒子模型 关于CSS重要的一个概念就是CSS盒子模型.它控制着页面这些元素的高度和宽度.盒子模型多少会让人产生一些困惑,尤其当涉及到高度和宽度计算的时候.真正盒子的宽度(在页面呈现出来的宽度)和高度, ...
- Java自学如何找工作
今天聊一下可能大多数人都关注的问题“自学Java如何找工作”那么首先你就要明确现在招聘Java开发的基本要求是什么?下面我们来看一下招聘网站上面的要求,在这里我只随便找了一个比较全面的要求,自己可以去 ...
- JS写一个简单日历
JS写一个日历,配合jQuery操作DOM <!DOCTYPE html> <html> <head> <meta charset="UTF-8&q ...
- UI设计篇·入门篇·绘制简单自定义矩形图/设置按钮按下弹起颜色变化/设置图形旋转
Android的基本控件和图形有限,难以满足所有的实际需要和设计需求,好在Android给出了相对完善的图形绘制和自定义控件的API,利用这些API,可以基本满足设计的需求. 自定义图像和控件的方法: ...
- Java虚拟机对象存活标记及垃圾收集算法解析
一.对象存活标记 1. 引用计数算法 给对象中添加一个引用计数器,每当有一个地方引用它时,计数器就加1:当引用失效时,计数器就减1:任何时刻计数器都为0的对象就是不可能再被使用的. 引用计数算法(Re ...