Couchbase介绍

  couchbase的关键有两点:延后写入和松散存储。延后写入,顾名思义,couchbase在对数据进行增删时会先体现在内存中,而不会立刻体现在硬盘上,从内存的修改到硬盘的修改这一步骤是由couchbase自动完成,等待执行的硬盘操作会以write queue的形式排队等待执行,也正是通过这个方法,硬盘的I/O效率在write queue满之前是不会影响couchbase的吞吐效率的,而write queue的长度是可以设置的。松散存储也很好理解,在关系型数据库中,要先建库建表,最后插数据,而在couchbase中bucket就相当于库,没有表的存在,直接就插数据了。关系型数据库依赖表来进行条件查询,couchbase一开始没有具备表功能的结构,所以是无法执行条件查询的,但是通过view则可以手动添加所需要的关系,view的设置是非常复杂的一部分。总之couchbase的一般逻辑是建bucket——>插入数据——>建立View。正是因为关系可以后天建立,才使得不必预先规划数据应具备的关系,随用随建即可。当然,对couchbase而言插入数据其实是插入json格式的文件。couchbase的精髓就在于依赖内存最大化降低硬盘I/O对吞吐量的负面影响。

Couchbase学习网址

Couchbase解释:https://segmentfault.com/a/1190000002907171
Couchbase学习:http://www.codeweblog.com/category/couchbase/
Couchbase官网:https://developer.couchbase.com/documentation/server/4.1/getting-started/first-n1ql-query.html
Couchbase Devloper's Guide2.0: (http://www.open-open.com/doc/view/d1dbdd84a413445f9594f3731f26f749  这本书讲的比较细
Couchbase Server:https://max.book118.com/html/2015/1016/27419732.shtm  很好

NuGet 添加

  CouchbaseNetClient

配置文件

  <configSections>
<sectionGroup name="couchbaseClients">
<section name="couchbase" type="Couchbase.Configuration.Client.Providers.CouchbaseClientSection, Couchbase"/>
</sectionGroup>
</configSections>
<couchbaseClients>
<couchbase>
<servers>
<add uri="http://localhost:8091"></add>
</servers>
<buckets>
<add name="default" password="" useSsl="false">
<connectionPool name="custom" maxSize="10" minSize="5" waitTimeout="5000" shutdownTimeout="3000"></connectionPool>
</add>
</buckets>
</couchbase>
</couchbaseClients>

C#代码例子

ClusterHelper.Initialize();
var cluster = ClusterHelper.Get();
using (var bucket = cluster.OpenBucket("default"))
{
//创建文档
for (int i = ; i < ; i++)
{
var testChild = new
{
FirstName = "张三",
Age = i > ? i % : i,
Gender = i % == ? "女" : "男"
}; string strGUID = "document_id_00" + i.ToString();
var doc = new Document<dynamic>
{
Id = strGUID,
Content = testChild
};
//没有数据新增,有数据更新
bucket.Upsert(doc);
} // 根据ID查询数据
var resultDoc = bucket.Get<string>("document_id_001");
//根据View查询数据 组合key
List<object> startKey = new List<object>() { "GetNan", };
List<object> endKey = new List<object>() { "GetNv", };
var view = bucket.CreateQuery("document_id", "Test").StartKey(startKey).EndKey(endKey);
var query = await bucket.QueryAsync<dynamic>(view);
//根据View查询数据 key
var view1 = bucket.CreateQuery("document_id", "Test2").StartKey().EndKey();
var query1 = await bucket.QueryAsync<dynamic>(view1);
}

Couchbase中View介绍

emit中第一个参数为key,第二个参数是返回值,组合key用[]括起来,doc为自己建的文档,meta默认的,有四个参数id等。简单来说就是emit中就是key,value

function (doc, meta) {
emit(doc.age, doc);
if(doc.gender=="男")
{
emit(["GetNan",doc.age],doc);
}
if(doc.gender=="女")
{
emit(["GetNv",doc.age],doc);
}
}

emit(["GetNv",doc.age],null);返回值为null的解释

1. index 會很大
2. couchbase在forum裡的技術說不要emit doc
3. 返回index是單線程, 自己寫拿取doc可以拼行
4. 我们称key-value生成的为primary index,id-key生成的为back index。
5. 如果用doc的话可能会引发类型为“System.OutOfMemoryException”的异常。

本地Couchbase 4.1文档

1. 下载java jdk
2. 配置环境变量
3. clone https://github.com/couchbase/docs-cb4/
4. clone https://github.com/couchbaselabs/dita-ot-2.1.1
5. 打开cmd窗口,进入dita-ot-2.1.1的bin目录,输入“dita -version”命令。如果显示“DITA-OT version 2.1.1”,则表示环境搭建OK。
6. dita -f html5 -i d:/GitProject/docs-cb4/content/cb-docs.ditamap -o d:/couchbaseDoc/output/
 其中-f表示发布文档保存格式,-i表示待发布的文档的顶级 ditamap 文件,-o 表示发布结果保存路径
7. 打开d:/couchbaseDoc/output/index.html 即可查看文档

创建indexex  ([`]这不是双引号也不是带引号是数字【1】左边的的)

1. 常见index
  CREATE INDEX `beer-sample-type-index` ON `beer-sample`(type) USING GSI WITH {"defer_build":true};
2. 查询是否创建成功
  SELECT * FROM system:indexes WHERE name="beer-sample-type-index";
3. build index
  BUILD INDEX ON `beer-sample`(`beer-sample-type-index`) USING GSI;
4. 查询数据
  SELECT * FROM `beer-sample` WHERE type="beer-sample-type-index";

Couchbase的优点

1.Couchbase 的对等网设计,smart client
2.直接获取整的集群的信息,在客户端实现负载均衡,整个集群没有单点失效,并且完全支持平行扩展。
3.vBucket 的引入,完全实现了 auto sharding,可以方便灵活的把数据的子集在不同节点上移动,以实现集群动态管理。
4.Couchbase 有一个非常专业的 web 管理界面,并且支持通过 RESTful API 管理,这也是 memcached,redis 不能企及的。
5.如果只是做 key/value 的 cache,Couchbase 可以完全取代 memcached。

Couchbase学习和使用的更多相关文章

  1. Couchbase学习记录

    Couchbase是membase的升级版,membase与memcache是同一家公司出的,Couchbase包含了memcache的功能. 从其官网上下载最新的版本安装即可.安装成功后会弹出设置页 ...

  2. 170多个Ionic Framework学习资源(转载)

    在Ionic官网找到的学习资源:http://blog.ionic.io/learning-ionic-in-your-living-room/ 网上的文章比较多,但是很多时候我们很难找到自己需要的. ...

  3. redis 学习笔记(5)-Spring与Jedis的集成

    首先不得不服Spring这个宇宙无敌的开源框架,几乎整合了所有流行的其它框架,http://projects.spring.io/spring-data/从这上面看,当下流行的redis.solr.h ...

  4. C#分布式缓存Couchbase使用

    目前C#业界使用得最多的 Cache 系统主要是 Memcached和 Redis. 这两个 Cache 系统可以说是比较成熟的解决方案,也是很多系统当然的选择. 一.简介 目前C#业界使用得最多的 ...

  5. C#分布式缓存二:Asp.Net中使用Couchbase

    前言 上一篇<C#分布式缓存一:Couchbase的安装与简单使用>主要讲解对Couchbase服务端的安装配置和客户端的引用调用,通过代码来完成最简单的实现调用.本次通过简单的配置,来完 ...

  6. C#分布式缓存一:Couchbase的安装与简单使用

    一.简介 目前C#业界使用得最多的 Cache 系统主要是 Memcached和 Redis. 这两个 Cache 系统可以说是比较成熟的解决方案,也是很多系统当然的选择. Memcache的开发团队 ...

  7. .Net分布式缓存应用实例:Couchbase

    转自:http://www.cnblogs.com/wu-jian Couchbase概述 Couchbase最早叫Membase,是由Memcached项目组的一些头目另立的山头. 2011年与Co ...

  8. C#分布式缓存Couchbase

    C#分布式缓存Couchbase使用 一.简介 目前C#业界使用得最多的 Cache 系统主要是 Memcached和 Redis. 这两个 Cache 系统可以说是比较成熟的解决方案,也是很多系统当 ...

  9. Asp.Net中使用Couchbase——Memcached缓存使用篇

    Asp.Net中使用Couchbase——Memcached缓存使用篇 前言 在上一篇Asp.Net中使用Couchbase——Memcached缓存入门篇http://www.cnblogs.com ...

随机推荐

  1. AMD and CMD are dead之KMDjs内核之分号

    在老版本的kmdjs中,强制了分号的要求.但是总感觉不爽,因为在开发Ket - Kmdjs Extension Tools的时候,总需要导入一些开源的库,然后痛苦就来了,总是报错,一查,就是缺少分号! ...

  2. tomcat memory leak

    Struts + Hibernate做项目,重新部署项目会出现Memory Leak严重报错.虽然不影响使用,但还是有风险.经实验发现是Hibernate的session没有关闭.....粗心....

  3. Highcharts使用手册

    chart: { type: 'area', ignoreHiddenSeries: false, //如果true,一旦一个系列被隐藏,轴将会扩展剩余的可见系列 }, 这是设置的两个纵坐标轴: yA ...

  4. C#函数参数传递解惑

    C#语言函数参数的传递   就像C语言众多的后世子孙一样,C#的函数参数是非常讲究的.首先,参数必须写在函数名后面的括号里,这里我们有必要称其为形参.参数必须有一个参数名称和明确的类型声明.该参数名称 ...

  5. 电脑中dll文件丢失怎么恢复?

    DLL文件是Windows系统中的动态链接文件,我们在运行程序时都必须链接到dll文件,如果缺少了则无法正常运行,相信大家都会遇到dll文件缺失的情况,那么电脑中dll文件丢失怎么恢复?下面装机之家分 ...

  6. JVM-索引

    JVM内容梳理 JVM体系结构 Jvm的体系结构 JVM内存区域详解(Eden Space.Survivor Space.Old Gen.Code Cache和Perm Gen) JVM之堆内存(年经 ...

  7. centos中less翻页查询的用法

    用法实例: cat 21342.log | less

  8. Cannot find snapshot in models/VGGNet/VOC0712/SSD_300x300

    错误描述: 执行 python examples/ssd/ssd_pascal.py 报错: Cannot find snapshot in models/VGGNet/VOC0712/SSD_300 ...

  9. 《Cocos2d-JS 开发之旅》即将发行,Cocos2d-x联合创始人林顺作序力荐

    受电子工业出版社邀请,经过半年多的酝酿,<Cocos2d-JS 开发之旅>(作者:郑高强)已经出版了,本书详细讲述如何使用Cocos2d-JS制作HTML5游戏和原生手机游戏,另外还有部分 ...

  10. SQL筛选出同一学科的时间最新的记录

    1.建表语句 CREATE TABLE `score` ( `id` ) NOT NULL AUTO_INCREMENT, `student_id` ) ' COMMENT '学生表ID', `nam ...