Elasticsearch7.5.2 常用rest api与elasticsearch库

目录

一、rest api

1. 新建索引

2. 删除索引

3. 插入单条数据

4. 更新单条数据

5. 删除单条数据

6. 查询数据

二、python elasticsearch库

1. 新建索引


一、rest api

1. 新建索引

请求方式:PUT

请求URL:http://ip/(your_index_name)

示例URL:http://ip/test_log_20240710-0

 数据参数:

params = {
    "settings": {
        "number_of_shards": 1,
        "number_of_replicas": 0
    },
    "aliases": {
        "test_log":{}
    },
    "mappings": {
        "properties": {
            "create_time": {
                "type": "date"
            },
            "status":{"type": "integer"},
            "dev_ip":{"type": "ip"},
            "dev_uuid":{"type": "keyword"},
            "user": {
                "properties": {
                    "name": {
                        "type": "text"
                    },
                    "age": {
                        "type": "integer"
                    },
                    "email": {
                        "type": "keyword"
                    }
                }
            },
            "infos": {
                "type": "nested",
                "dynamic": false,
                "properties": {
                    "v_id": {"type": "keyword"},
                    "v_name": {"type": "keyword"},
                    "v_desc": {"type": "text"}
                }
            },
            "remark": {"type": "text"},
            "show_num": {"type": "long", "doc_values": false, "index": false}
        }
    }
}


"""
字段类型:

text:用于全文本搜索,如文章内容。text字段会被分析器分词,支持模糊搜索和前缀搜索。
keyword:用于不进行分词的搜索,适合存储关键词、ID、标签等。keyword字段不会被分词,适用于精确匹配和聚合。
integer/long/short/byte/double/float/half_float/scaled_float:用于数值类型的数据,不同的类型对应不同的数值范围和精度。
boolean:布尔型字段,值只能是true或false。
binary:用于存储二进制数据,如图像或文件。
date:日期时间字段,可以使用ISO8601格式的字符串或毫秒级的时间戳。
date_nanos:纳秒精度的日期时间字段,存储为纳秒时间戳。
ip:用于存储IPv4或IPv6地址。
object:用于嵌套的JSON对象。可以定义内部字段的映射。
nested:用于存储复杂结构的嵌套文档,允许对嵌套文档进行独立索引和搜索。
geo_point:用于地理坐标,支持基于地理位置的查询。
geo_shape:用于地理形状,如多边形,支持更复杂的地理查询。
completion:用于自动补全功能,存储经过分析的词条列表。
constant_keyword:与keyword类似,但值在索引时会被复制到所有分片,加速聚合操作。
token_count:用于存储分词后的词数。
"""

2. 删除索引

请求方式:DELETE

请求URL:http://ip/(your_index_name)

示例URL:http://ip/test_log_20240710-0

3. 插入单条数据

请求方式:POST

请求URL:http://ip/(your_index_name)

示例URL:http://ip/test_log_20240710-0

数据参数:

{
  "create_time": 1720601022255,
  "status": 201,
  "dev_ip": "192.168.1.101",
  "dev_uuid": "123e4567e89b12d3a456426614174000",
  "user": {
    "name": "战三",
    "age": 30,
    "email": "zhansan@example.com"
  },
  "infos": [
    {
      "v_id": "123e4567e89b12d3a456426614174000",
      "v_name": "战三",
      "v_desc": "描述啦啦啦啦啦啦"
    }
  ],
  "remark": "描述!!!!!",
  "show_num": 6789
}

4. 更新单条数据

请求方式:PUT

请求URL:http://ip/(your_index_name)/_doc/(本条记录id)

示例URL:http://ip/test_log_20240710-0/_doc/KjjOm5ABJ5wlHmqgfJvm

数据参数:

{
  "create_time": "2023-04-01T12:00:00Z",
  "status": 200,
  "dev_ip": "192.168.1.100",
  "dev_uuid": "123e4567-e89b-12d3-a456-426614174000",
  "user": {
    "name": "阿汉",
    "age": 30,
    "email": "john.doe@example.com"
  },
  "infos": [
    {
      "v_id": "info1",
      "v_name": "Info One",
      "v_desc": "This is the description of info one."
    },
    {
      "v_id": "info2",
      "v_name": "Info Two",
      "v_desc": "This is the description of info two."
    }
  ],
  "remark": "Additional remarks about this log entry.",
  "show_num": 12345
}

5. 删除单条数据

请求方式:DELETE

请求URL:http://ip/(your_index_name)/_doc/(本条记录id)

示例URL:http://ip/test_log_20240710-0/_doc/KjjOm5ABJ5wlHmqgfJvm

数据参数:无

6. 查询数据

请求方式:POST

请求URL:http://ip/(your_index_name)/_search

示例URL:http://ip/test_log_20240710-0/_search

数据参数:

{
    "size": 10,
    "query": {
        "bool": {
            "must": [
                {
                    "term": {
                        "status": 200
                    }
                }
            ]
        }
    }
}

二、python elasticsearch库

1. 新建索引

......

相关推荐

  1. Elasticsearch7.5.2 rest apielasticsearch

    2024-07-10 19:34:03       9 阅读
  2. elasticsearch命令

    2024-07-10 19:34:03       33 阅读
  3. Elasticsearch语句

    2024-07-10 19:34:03       21 阅读
  4. Elasticsearch 优化思路

    2024-07-10 19:34:03       42 阅读
  5. ElasticSearch搜索语句SQL对比

    2024-07-10 19:34:03       41 阅读
  6. ElasticSearch 排障方法

    2024-07-10 19:34:03       52 阅读
  7. ElasticSearch基础及查询

    2024-07-10 19:34:03       45 阅读
  8. ElasticsearchDSL语句

    2024-07-10 19:34:03       38 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-07-10 19:34:03       5 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-07-10 19:34:03       5 阅读
  3. 在Django里面运行非项目文件

    2024-07-10 19:34:03       4 阅读
  4. Python语言-面向对象

    2024-07-10 19:34:03       7 阅读

热门阅读

  1. MySQL 的 Buffer Pool 的结构及有什么作用

    2024-07-10 19:34:03       10 阅读
  2. 【大模型】解锁语言模型潜能:提示工程的艺术

    2024-07-10 19:34:03       10 阅读
  3. docker run enteypoint怎么样使用呢?

    2024-07-10 19:34:03       8 阅读
  4. kafka中

    kafka中

    2024-07-10 19:34:03      10 阅读
  5. 探索Vue.js:构建高效前端应用的现代框架

    2024-07-10 19:34:03       6 阅读
  6. ffmpeg 获取视频时长的命令及其输出

    2024-07-10 19:34:03       10 阅读
  7. 使用Python绘制甘特图

    2024-07-10 19:34:03       12 阅读
  8. uboot spi nor flash初始化相关的阅读分析(一)

    2024-07-10 19:34:03       10 阅读
  9. 最小生成树(算法篇)

    2024-07-10 19:34:03       10 阅读
  10. K8S集群应用国产信创适配实战经验总结

    2024-07-10 19:34:03       8 阅读
  11. 方程与不等式

    2024-07-10 19:34:03       12 阅读
  12. 力扣1472.设计浏览器历史记录

    2024-07-10 19:34:03       12 阅读
  13. ArcGIS Pro SDK (八)地理数据库 3 数据

    2024-07-10 19:34:03       11 阅读
  14. C语言 找出一个二维数组中的鞍点

    2024-07-10 19:34:03       10 阅读