CURL的操作

  curl是利用URL语法在命令行方式下工作的开源文件传输工具,使用url可以简单实现常见的get/post请求。简单的认为是可以在命令行下面访问url的一个工具。在centos的默认库里面是有curl工具的,如果没有请yum安装即可。

curl

-X 指定http的请求方法有 HEAD GET POST PUT DELETE

-d 指定要传输的数据

-H 指定http请求头信息

liulanES服务器: curl -XGET http://master:9200 <=> 在浏览器中访问

查看es的状态

curl -k -u admin:admin -XGET https://xxx:9200/_cluster/health?pretty

查看index

curl -k -u admin:admin 'https://master:9200/_cat/indices?v'

一、创建索引库:

curl -XPUT https://master:9200/bigdata_p

curl -k -u username:passwd -XPUT https://master:9200/bigdata_p 

这样在es中就创建了一个索引库bigdata_p

POST和PUT都可以用于创建,二者之间的区别:

PUT是幂等方法,POST不是。所以PUT用于更新,POST用于新增比较合适。

ES创建索引库和索引时的注意点:

1)索引库名称必须要全部小写,不能以下划线开头,也不能包含逗号

2)如果没有明确指定索引数据ID,那么es会自动生成一个随机的ID,需要使用POST参数

curl -k -u  admin:admin -XPOST https://master:9200/bigdata_p/product/1 -d '{"author" : "Doug Cutting"}'

 

二、向库中新增数据

在具体的type里面,添加相关的document

curl -k -u username:passwd -XPOST https://master:9200/bigdata/product/ -d '{"name":"hadoop", "author": "Doug Cutting", "c_version": "2.7.3"}' 

三、查询某一个索引库中的数据

查询整个索引库:

curl -k -u admin:admin -XGET https://master:9200/bigdata_p/_search?pretty

在url后面加上一个pretty则会对返回结果进行格式化。

查询某一个type:
curl -k -u admin:admin -XGET https://master:9200/bigdata/product/_search?pretty
查询具体的某一条记录:
curl -k -u username:passwd -XGET https://master:9200/bigdata/product/1?pretty

查询一条索引文档中的具体的字段:

curl -k -u admin:admin -XGET https://master:9200/bigdata_p/product/1?_source=name&pretty

如果需要查询多个字段,使用逗号进行隔开,eg:
curl -k -u username:passwd -XGET https://master:9200/bigdata/product/AWqHg_E7HpMjdaKC2sgv?_source=name,c_version&pretty

获取source所有数据:(可以通过source指定显示哪些字段,不指定就是显示全部字段)
curl -k -u admin:admin -XGET https://master:9200/bigdata/product/AWqHg_E7HpMjdaKC2sgv?_source&pretty

根据条件进行查询:

curl -k -u admin:admin -XGET https://master:9200/bigdata/product/_search?q=name:hadoop&pretty

 

三、ES更新

   ES可以使用PUT或者POST对文档进行更新,如果指定ID的文档已经存在,则执行更新操作

  注意:执行更新操作的时候,ES首先将旧的文档标记为删除状态,然后添加新的文档,旧的文档不会立即消失,但是你也无法访问,ES会继续添加更多数据的时候在后台清理已经标记为删除状态的文档。

  局部更新

curl -k -u admin:admin -XPOST https://master:9200/bigdata/product/AWqHg_E7HpMjdaKC2sgv/_update -d '{"doc":{"c_version": "2.0.0", "publish_time": "2017-03-23"}}' 

 

四、删除

普通删除,根据主键删除(删除type的一个文档)

curl -k -u admin:admin -XDELETE https://maser:9200/bigdata/product/AWqHg_E7HpMjdaKC2sgv/ 

说明:如果文档存在,es属性found:true,successflu:1,_version属性的值 +1.

如果文档不存在,es属性found为false,但是版本值version依然会+1,这个就是内部。

注意:一个文档被删除之后,不会立即生效,他只是被标记为已删除。ES将会在你之后添加了更多索引的时候才会在后台进行删除。

删除index

curl -k -u admin:admin -X DELETE 'https://master:9200/bigdata'

五、ES之settings和mapping的意义

(一)settings

简单来说,就是:

  settings是修改分片和副本数的。

  mappings是修改字段和类型的。

  查询索引库中的settings信息:

  curl -k -u admin:admin -XGET 'https://master:9200/bigdata_p/_settings?pretty'

"number_of_shards"  主分片

"number_of_replicas"  副本数

 总结:不存在索引时,可以指定副本和分片。

    如果存在索引,则只能修改副本。

   在创建新的索引库时,可以指定索引分片的副本数。默认是1。

 

 (二)mapping

es中,index相当于数据库,type相当于表,而mapping相当于表结构。

mapping不仅告诉es一个field中是什么类型的值,它还告诉es如何索引数据以及数据是否能被搜索到。

curl -k -u admin:admin -XGET 'https://master:9200/bigdata_p/_mapping?pretty'

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

  

 

posted on 2019-05-07 11:35  风清_云淡  阅读(25104)  评论(2编辑  收藏  举报