初探elasticsearch
2024-09-05 15:02:26
目录
安装elasticsearch
- 准备java环境
- 下载安装elasticsearch
- 安装插件
- marvel: 开发环境下免费,是elasticsearch的管理和监控工具,它包含了一个叫做Sense的交互式控制台,使用户方便的通过浏览器直接与Elasticsearch进行交互
./bin/plugin -i elasticsearch/marvel/latest
# 禁用marvel
echo 'marvel.agent.enabled: false' >> ./config/elasticsearch.yml
elasticsearch中的层级结构与关系型数据库的对比
- 在Elasticsearch中存储数据的行为就叫做索引(indexing),不过在索引之前,我们需要明确数据应该存储在哪里
- 在Elasticsearch中,文档归属于一种类型(type),而这些类型存在于索引(index)中
Relational DB -> Databases -> Tables -> Rows -> Columns
Elasticsearch -> Indices -> Types -> Documents -> Fields
elasticsearch的分布式特性
Elasticsearch致力于隐藏分布式系统的复杂性。以下这些操作都是在底层自动完成的:
- 将你的文档分区到不同的容器或者分片(shards)中,它们可以存在于一个或多个节点中。
- 将分片均匀的分配到各个节点,对索引和搜索做负载均衡。
- 冗余每一个分片,防止硬件故障造成的数据丢失。
- 将集群中任意一个节点上的请求路由到相应数据所在的节点。
- 无论是增加节点,还是移除节点,分片都可以做到无缝的扩展和迁移
集群和节点
- 节点(node)是一个运行着的Elasticsearch实例。集群(cluster)是一组具有相同cluster.name的节点集合,他们协同工作,共享数据并提供故障转移和扩展功能,当然一个节点也可以组成一个集群。
- 你最好找一个合适的名字来替代cluster.name的默认值,比如你自己的名字,这样可以防止一个新启动的节点加入到相同网络中的另一个同名的集群中
为java用户提供的两种内置客户端
节点客户端(node client)
节点客户端以无数据节点(none data node)身份加入集群,换言之,它自己不存储任何数据,但是它知道数据在集群中的具体位置,并且能够直接转发请求到对应的节点上
传输客户端(Transport client)
这个更轻量的传输客户端能够发送请求到远程集群。它自己不加入集群,只是简单转发请求给集群中的节点。
两个Java客户端都通过9300端口与集群交互,使用Elasticsearch传输协议(Elasticsearch Transport Protocol)。集群中的节点之间也通过9300端口进行通信。如果此端口未开放,你的节点将不能组成集群
基于HTTP协议,以JSON为数据交互格式的RESTful API
其他所有程序语言都可以使用RESTful API,通过9200端口的与Elasticsearch进行通信,你可以使用你喜欢的WEB客户端,事实上,如你所见,你甚至可以通过curl命令与Elasticsearch通信
Elasticsearch官方提供了多种程序语言的客户端——Groovy,Javascript, .NET,PHP,Perl,Python,以及 Ruby——还有很多由社区提供的客户端和插件,所有这些可以在文档中找到
http请求的格式
curl -X<VERB> '<PROTOCOL>://<HOST>:<PORT>/<PATH>?<QUERY_STRING>' -d '<BODY>'
- VERB HTTP方法:GET, POST, PUT, HEAD, DELETE
- PROTOCOL http或者https协议(只有在Elasticsearch前面有https代理的时候可用)
- HOST Elasticsearch集群中的任何一个节点的主机名,如果是在本地的节点,那么就叫localhost
- PORT Elasticsearch HTTP服务所在的端口,默认为9200
- PATH API路径(例如_count将返回集群中文档的数量),PATH可以包含多个组件,例如_cluster/stats或者_nodes/stats/jvm
- QUERY_STRING 一些可选的查询请求参数,例如?pretty参数将使请求返回更加美观易读的JSON数据
- BODY 一个JSON格式的请求主体(如果请求需要的话)
最新文章
- STL";源码";剖析-重点知识总结
- 【转】各版本IIS下ASP.net请求处理过程区别
- ios 获取通讯录的所有信息
- Linux 配置本地yum源
- mysql查看表的结构
- 静态资源库CDN服务
- mysql安装前的系统准备工作(转)
- 使用 Buildot 实现持续集成
- [即时通讯]openfire启动失败解决办法
- 用 Docker Machine 创建 Azure 虚拟主机
- node框架express
- week07 13.1 NewsPipeline之 一 NewsMonitor
- C#后台Post提交XML 及接收该XML的方法
- 2010-2011 ACM-ICPC, NEERC, Moscow Subregional Contest Problem D. Distance 迪杰斯特拉
- IOS设计模式第二篇之单例设计模式
- [ACM_数据结构] POJ2352 [树状数组稍微变形]
- aapt命令获取apk详细信息(包名、版本号、版本名称、兼容api级别、启动Activity等)
- python3安装后无法使用退格键的问题
- python 读写三菱PLC数据,使用以太网读写Q系列,L系列,Fx系列的PLC数据
- Linux gcc支持的语法 __attribute__ 属性设置