最近有空就想研究下ElasticSearch。

此篇文章用来记录研究过程。备注:需要有一定的docker基础,ElasticSearch的基本概念

Docker安装ElasticSearch

首先,就是安装ElasticSearch。 因为有了docker,所以就不用按部就班的安装,直接通过下载ElasticSearch的镜像源就搞定。

理想是美好的,现实是残酷的。因为从国外拉取镜像太慢,我选择了国内的时速云。结果搜索ElasticSearch排名第一的镜像把我坑惨了,死活连不上。

只能慢慢找对应官网的镜像,我只是想吐槽下国内...国内...

1.下载镜像

docker pull index.tenxcloud.com/docker_library/elasticsearch:1.6

2. 开启镜像并映射端口9200(ElasticSearch的默认端口为9200)

docker run -p : -d index.tenxcloud.com/docker_library/elasticsearch:1.6

备注:如果是mac的话,还需要多在此之前多做一个端口映射的动作,具体可参照http://unmi.cc/mac-os-x-experience-docker/中的端口映射,

里面的流程图也说明了为何mac需要再多做一步。

3.测试是否安装成功,并且能够连通

curl 127.0.0.1:

这时候,会看到正常返回:

{
"status" : 200,
"name" : "James \"Jimmy\" Marks",
"cluster_name" : "elasticsearch",
"version" : {
"number" : "1.6.2",
"build_hash" : "622039121e53e5f520b5ff8720fdbd3d0cb5326b",
"build_timestamp" : "2015-07-29T09:24:47Z",
"build_snapshot" : false,
"lucene_version" : "4.10.4"
},
"tagline" : "You Know, for Search"
}

Elasticsearch

与Elasticsearch交互

任何其他语言都可以使用你喜欢的网页客户端可以访问的RESTful API通过9200端口和 Elasticsearch通信。实际上,你甚至可以从命令行通过curl命令(当然你要去了解一下curl命令)和Elasticsearch通信。

curl -XGET 'http://localhost:9200/_count?pretty'
-d '
{
"query": {
"match_all": {}
}
}
'

说明:

-XGET适当的HTTP方法或者动作 : GET、POST、PUT、HEAD或者DELETE;

http:.........:9200表示集群任意节点的协议、主机名和端口;

_count表示请求的路径;

pretty任意可选的查询字符串参数,比如pretty将会漂亮的打印JSON格式的响应使它更容易阅读;

-d表示 HTTP POST方式传输数据;

{}中的部分表示JSON格式的请求包体(我们后面会常用这种形式);

query表示JSON格式的请求包体中的查询关键字;

match_all表示JSON格式的请求包体中的要查询的字段。Elasticsearch返回一个像 200 OK 的状态码和一个JSON格式的响应(HEAD请求除外)。 上面的curl请求将返回一个如下的JSON格式的响应:

{
"count" : 0,
"_shards" : {
"total" : 5,
"successful" : 5,
"failed" : 0
}
}

建立索引

Elasticsearch中建立一个索引来存储数据。比如我创建的索引是article。

curl -XPUT 'http://localhost:9200/article/'  

返回结果为:

{"acknowledged":true}

建立mapping

我们已经建立索引名为article的索引,我们在这将对article中的内容进行约束,进行验证。从而在存取数据时按照我们预定的规则进行存储。也就是我们在这里要建立article的mapping。下面代码是建立索引为article,索引类型为detail的mapping

curl -XPUT 'http://localhost:9200/article/_mapping/detail' -d '
{
"detail" : {
"dynamic" : true,
"properties" : {
"title" : { "type" : "string" },
"url" : { "type" : "string" },
"content" : { "type" : "string" }
}
}
}
'

返回结果为:

{"acknowledged":true}

数据保存

curl -XPOST  'http://localhost:9200/article/detail' -d '{
"title":"hello world!",
"url": "http://xxxx.com",
"content":"this is a test"
}'

返回结果:

{"_index":"article","_type":"detail","_id":"AVYrA6DFR3LFkvR34Ega","_version":1,"created":true}

ES数据检索

curl -XGET 'http://localhost:9200/article/detail/_search' -d '
{
"query":
{
"match":
{"content":"test"}
}
}'

返回结果:

{"took":7,"timed_out":false,"_shards":{"total":5,"successful":5,"failed":0},"hits":{"total":1,"max_score":0.15342641,"hits":[{"_index":"article","_type":"detail","_id":"AVYrA6DFR3LFkvR34Ega","_score":0.15342641,"_source":{
"title":"hello world!",
"url": "http://xxxx.com",
"content":"this is a test"
}}]}}

Node.js

node.js也有相关的elasticsearch包。

首先安装下:

npm install elasticsearch

初始化:

var elasticsearch = require('elasticsearch');
var client = new elasticsearch.Client({
host: 'localhost:9200',
log: 'trace'
});

试试下,我们通过node查找刚刚插入的数据

client.search({
index: 'article',
type: 'detail',
body: {
query: {
match: {
content: 'test'
}
}
}
}).then(function (resp) {
var hits = resp.hits.hits;
}, function (err) {
console.trace(err.message);
});

看下日志,哦啦!

暂时就研究了那么多,更加深入的待续......

Docker + ElasticSearch + Node.js的更多相关文章

  1. [第十八篇]——Docker 安装 Node.js之Spring Cloud大型企业分布式微服务云架构源码

    Docker 安装 Node.js Node.js 是一个基于 Chrome V8 引擎的 JavaScript 运行环境,是一个让 JavaScript 运行在服务端的开发平台. 1.查看可用的 N ...

  2. Docker 生成Node.js web app(含端口映射)

    1.新建目录src,并进入src目录 [xiejdm@localhost Documents]$ mkdir src [xiejdm@localhost Documents]$ cd src/ 2.创 ...

  3. 利用Docker设置Node.js

      docker是一个开源的应用容器引擎,可以为我们提供安全.可移植.可重复的自动化部署的方式.docker采用虚拟化的技术来虚拟化出应用程序的运行环境.如上图一样.docker就像一艘轮船.而轮船上 ...

  4. [Docker] Linking Node.js and MongoDB Containers

    To do communcation between containers, we need to do link between containers. 1. Run a container wit ...

  5. docker部署node.js

    1.dockerfile FROM node:14.16.0 RUN mkdir -p /var/log/lily/ RUN mkdir -p /opt/node # 工作目录 WORKDIR /op ...

  6. Node.js 指南(迁移到安全的Buffer构造函数)

    迁移到安全的Buffer构造函数 移植到Buffer.from()/Buffer.alloc() API. 概述 本指南介绍了如何迁移到安全的Buffer构造函数方法,迁移修复了以下弃用警告: 由于安 ...

  7. 实践案例丨教你一键构建部署发布前端和Node.js服务

    如何使用华为云服务一键构建部署发布前端和Node.js服务 构建部署,一直是一个很繁琐的过程 作为开发,最害怕遇到版本发布,特别是前.后端一起上线发布,项目又特别多的时候. 例如你有10个项目,前后端 ...

  8. 当Node.js遇见Docker

    Node.js Best Practices - How to Become a Better Developer in 2017提到的几点,我们Fundebug深有同感: 使用ES6 使用Promi ...

  9. Docker常见仓库Node.js

    Node.js 基本信息 Node.js是基于 JavaScript 的可扩展服务端和网络软件开发平台. 该仓库提供了 Node.js 0.8 ~ 0.11 各个版本的镜像. 使用方法 在项目中创建一 ...

随机推荐

  1. PNP管理器简析--基于ReactOS0.33

    CSDN上转悠了一圈发现关于PNP管理的文章不多.那就由我献个丑,记录自己对PNP管理器的看法. pnp管理器被描写叙述为向内核和应用程序提供关于设备拔插的通知,凭感觉,pnp管理器应该是个线程函数等 ...

  2. WP8 NavigationInTransition实现页面切换效果

    NavigationInTransition这个是实现页面切换效果,而且没控件来拖,要自己手动写, 将App.xaml.cs中InitializePhoneApplication()函数里的RootF ...

  3. js常用工具

    1.反编译工具 .NET Reflector 2.js检查工具 ReSharper 8.0.14.856 官方原版+注册机     JScript Editor Extensions     JSEn ...

  4. ie6、ie7下JSON.parse JSON未定义的解决方法

    解决方法一: var jsons = req.responseText; var s; if (typeof(JSON) == 'undefined'){ s = eval("(" ...

  5. 通过windows自带的系统监视器来查看IIS并发连接数(perfmon.msc)

    如果要查看IIS连接数,最简单方便的方法是通过“网站统计”来查看,“网站统计”的当前在线人数可以认为是当前IIS连接数.然而,“网站统计”的当前在线人数统计时间较长,一般为10分钟或15分钟,再加上统 ...

  6. HDU - 1816 Get Luffy Out *(二分 + 2-SAT)

    题目大意:有N串钥匙,M对锁.每串钥匙仅仅能选择当中一把.怎样选择,才干使开的锁达到最大(锁仅仅能按顺序一对一对开.仅仅要开了当中一个锁就可以) 解题思路:这题跟HDU - 3715 Go Deepe ...

  7. sapjco3 开发与部署环境设置

    windows 环境设置 1.sapjco3.dll 需要与 sapjco3.jar 在同一目录 2.设置系统环境变量,将sapjco3所在目录加入系统环境变量 3.根据自己的操作系统版本选择对应的s ...

  8. mysql官网下载页面

    http://dev.mysql.com/downloads/mysql/5.6.html#downloads

  9. 键值对集合 dict(字典)

    xx= { ss, ss } 创建字典 len(ss) 返回字典到长度,len函数可以返回任何集合的长度,list.tuple.dict都是集合的一种 什么是dict 我们已经知道,list 和 tu ...

  10. mock实例方法

    1.Mockito.when(categoryService.queryTopCategory("1")).thenReturn(categories);//返回的是list列表, ...