一个C++的ElasticSearch Client

2019-08-16 07:56:44来源:博客园 阅读 ()

新老客户大回馈,云服务器低至5折

一个C++的ElasticSearch Client

ElasticSearch官方是没有提供C++的client的;因此决定自己写一个,命名为ESClient https://github.com/ATinyAnt/ESClient(手下留星 star)

优势是简单易用:

* 封装大幅度减少了直接写DSL的机会,避免了一些非逻辑错误

* 只需要包含头文件 request.h即可以使用

* 复杂的语句,可支持用原生(Raw)Json嵌套

目前ESClient只支持常用的搜索短语,暂不支持插入、更新、删除和响应处理;原因是我们做ElasticSearch服务时,一般只会用到搜索,而数据一般由其它进程清洗后,插入到ElasticSearch中。并不是由当前的服务来进行增、删、改。当然后续会陆续完善这一部分(也希望你们可以帮忙完善)。

这个Client,我并不想加入Http模块,因为我认为加入Http,很容易会侵入了使用者原来的架构。因此,这只是做一个DSL的编码器;编码得到json,可由使用者当前架构的Http模块调用。

以下是两个使用例子

#include "request.h"

using namespace ES;
Request r;
std::string dsl = r.Size(10).Source({ "id" }).Query(RegExp("name", ".*Tiny.*"));
printf("%s\n",  dsl.c_str());
// {"size":10,"_source":["id"],"query":{"regexp":{"name":".*Tiny.*"}}}
#include "request.h"

using namespace ES;
Request r;
std::string dsl = r.Size(10).Source({"name"}).Sort(
    {MakeObject("timestamp",MakeObjectString("order", "desc"))}
    ).Query(
        Range1(
        "id",
        MakePair("lt",567)
    ));
printf("%s\n", dsl.c_str());
// {"size":10,"_source":["name"],"sort":[{"timestamp":{"order":"desc"}}],"query":{"range":{"id":{"lt":567}}}}

 


原文链接:https://www.cnblogs.com/atinyant/p/11285122.html
如有疑问请与原作者联系

标签:

版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com
特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有

上一篇:【调试经验】C++和C的混合编程以及库调用

下一篇:C/C++快读(快速读入)有多——安全AC