elasticsearch6.5.4索引

本文围绕elasticsearch6.5.4索引展开,介绍了创建索引需依赖elasticsearch包并使用pip安装,还阐述了分片和副本的概念,可规定其数量或使用默认值。同时说明了映射配置,包括数据类型如字符串、数字等,以及属性如index、store、boost等。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

elasticsearch6.5.4索引

一:创建索引

1.依赖 elasticsearch包,pip install elasticsearch 安装
2.python2

# -*- coding: utf-8 -*-
import json
from elasticsearch import Elasticsearch
from elasticsearch.helpers import bulk
ES_HOST = '127.0.0.1'  # es ip
ES_USER = ''  # es 账号
ES_PASSWD = ''  # es 密码
ES_PORT = 9002  # es 端口


class ES():
    def __init__(self):
        self.es = Elasticsearch([ES_HOST], http_auth=(ES_USER,ES_PASSWD), port=ES_PORT, timeout=300)

    def create_index(self, index):
        mappings = {
		    "settings": {
				"number_of_shards": 3,  # 数据自动会分成3片存放在不同的节点,提高数据检索速度
				"number_of_replicas": 0  # 创建0个副本集,如果ES是集群,设置多副本会自动将副本创建到多个节点;设置多副本可以增加数据库的安全性,但是插数据的时候,会先向主节点插入数据,之后再向其余副本同步,会降低插入数据速度,差不多会降低1.4到1.6倍
		    },
		    "mappings": {
		        "book": {  # 索引名
				    "dynamic": True,  # 开启自动添加字段
				    "numeric_detection" : True  # 数字自动检测,当执行索引操作时,如果符合float型,就会自动创建为float
				    "properties": {
						"author": {"type": "text", "boost": 2},
						"characters": {"type": "text"},
						"copies": {"type": "long", "ignore_malformed": False},
						"otitle": {"type": "text"},
						"tags": {"type": "text"},
						"title": {"type": "text"},
						"year": {"type": "long", "ignore_malformed": False, "index": True},
						"available": {"type": "boolean"}
					}
				}
	   		}
		}
		rtn = self.es.indices.create(index=index, body=mappings, ignore=400)
        print rtn

if __name__ == '__main__':
    es = ES()
    index = 'test_01'
    es.create_index(index)

二:分片和副本

Elasticsearch索引是由一个或多个分片组成的,每个分片包含了文档集的 一部分。而且这些分片也可以有副本,它们是分片的完整副本。在创建索引的过程中,可以规定 应创建的分片及副本的数量。也可以忽略这些信息,直接使用Elasticsearch内部实现的默认值(5个分片及1个副本)。
一般而言,同时具有分片和与其相应的副本,意味着建立索引文档时,两者都得修改。这是 因为要使分片得到精确的副本,Elasticsearch需将分片的变动通知所有副本。 要读取文件,可 以使用分片或者其副本。在具有许多 理节点的系统中,可以把分片和副本放置于不同节点上, 从而发 更多处理能力(如磁盘I/O或CPU)。

三:映射配置

Elasticsearch是一个无模式的搜索引擎,可以即时算出数据结构。

数据类型
字符串text
数字integer、byte、short、long、float、double
日期date
布尔boolean
二进制binary

属性
index: true or false 是否编入索引。默认为true。将index设置为false,则不索引,即不能对其检索
store:true or false 原始值是否编入_source。默认false,当某个数据字段很大,我们可以指定其它字段store为true,这样就不用从_source中取数据,这时候会在 _source 存储之外再为这个字段独立进行存储。
boost:数值,boost的值越高,字段中值的重要性越高

### MCU低功耗模式下的GPIO配置MCU运行于低功耗模式时,合理配置GPIO对于降低整体能耗至关重要。以下是关于如何在低功耗环境下优化和配置GPIO的一些方法以及示例代码。 #### 1. 关闭使用GPIO端口 为了减少漏电流,在低功耗模式下应关闭所有不需要的GPIO端口。可以通过设置相应的寄存器来实现这一目标。例如: ```c // 假设使用的是STM32系列MCU GPIO_InitTypeDef GPIO_InitStruct; // 设置GPIOA的所有引脚为模拟输入状态(高阻态) GPIO_InitStruct.Pin = GPIO_PIN_All; GPIO_InitStruct.Mode = GPIO_MODE_ANALOG; GPIO_InitStruct.Pull = GPIO_NOPULL; HAL_GPIO_Init(GPIOA, &GPIO_InitStruct); ``` 此代码片段将整个GPIOA端口配置为模拟输入模式[^1],从而避免不必要的电流失控。 #### 2. 使用弱上拉/下拉电阻 如果某些GPIO需要保持特定的状态,则可以启用内部弱上拉或下拉电阻而不是外部组件。这样不仅可以节省空间还能进一步减小静态功耗。 ```c // 将PA0配置成输入并激活下拉电阻 GPIO_InitStruct.Pin = GPIO_PIN_0; GPIO_InitStruct.Mode = GPIO_MODE_INPUT; GPIO_InitStruct.Pull = GPIO_PULLDOWN; HAL_GPIO_Init(GPIOA, &GPIO_InitStruct); ``` 通过这种方式可以在不增加额外硬件的情况下维持信号稳定[^1]。 #### 3. 减少开关频率 频繁切换IO状态会消耗更多能量。因此,在设计应用程序逻辑时应该尽量减少这种变化次数。比如当检测按键按下事件时采用去抖动算法而非简单轮询法。 #### 示例代码:进入STOP模式前准备GPIO 下面给出一段综合考虑以上几点因素后的实际应用例子——让系统进入停止(Stop)模式之前做好必要的准备工作: ```c void EnterLowPowerMode(void){ // 初始化GPIO结构体变量 GPIO_InitTypeDef GPIO_InitStruct; // 配置LED指示灯所在的管脚(PB5),默认熄灭 __HAL_RCC_GPIOB_CLK_ENABLE(); GPIO_InitStruct.Pin = GPIO_PIN_5; GPIO_InitStruct.Mode = GPIO_MODE_OUTPUT_PP; GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_LOW; GPIO_InitStruct.Pull = GPIO_NOPULL; HAL_GPIO_Init(GPIOB,&GPIO_InitStruct); HAL_GPIO_WritePin(GPIOB,GPIO_PIN_5,GPIO_PIN_RESET); // 把其他不用的工作外设对应的I/O都改为浮空输入或者模拟输入形式 __HAL_RCC_GPIOA_CLK_ENABLE(); GPIO_InitStruct.Pin = GPIO_PIN_All; GPIO_InitStruct.Mode = GPIO_MODE_ANALOG; GPIO_InitStruct.Pull = GPIO_NOPULL; HAL_GPIO_Init(GPIOA,&GPIO_InitStruct); // 进入STOP Mode... } ``` 该函数首先确保任何可能影响唤醒过程的功能都被禁用了;其次把那些平时处于活动状态但此时不再需要工作的外围设备关联起来的针脚重新定义成了最低限度耗能的形式^。 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值