Elasticsearch - Guía rápida
Elasticsearch es un servidor de búsqueda basado en Apache Lucene. Fue desarrollado por Shay Banon y publicado en 2010. Ahora es mantenido por Elasticsearch BV. Su última versión es 7.0.0.
Elasticsearch es un motor de análisis y búsqueda de texto completo distribuido en tiempo real y de código abierto. Se puede acceder a él desde la interfaz de servicio web RESTful y utiliza documentos JSON (notación de objetos JavaScript) sin esquema para almacenar datos. Está construido sobre el lenguaje de programación Java y, por lo tanto, Elasticsearch puede ejecutarse en diferentes plataformas. Permite a los usuarios explorar una gran cantidad de datos a muy alta velocidad.
Características generales
Las características generales de Elasticsearch son las siguientes:
Elasticsearch es escalable hasta petabytes de datos estructurados y no estructurados.
Elasticsearch se puede utilizar como reemplazo de almacenes de documentos como MongoDB y RavenDB.
Elasticsearch utiliza la desnormalización para mejorar el rendimiento de la búsqueda.
Elasticsearch es uno de los motores de búsqueda empresarial más populares y actualmente está siendo utilizado por muchas grandes organizaciones como Wikipedia, The Guardian, StackOverflow, GitHub, etc.
Elasticsearch es de código abierto y está disponible bajo la licencia Apache versión 2.0.
Conceptos clave
Los conceptos clave de Elasticsearch son los siguientes:
Nodo
Se refiere a una única instancia en ejecución de Elasticsearch. Un solo servidor físico y virtual acomoda múltiples nodos dependiendo de las capacidades de sus recursos físicos como RAM, almacenamiento y potencia de procesamiento.
Racimo
Es una colección de uno o más nodos. Cluster proporciona capacidades colectivas de indexación y búsqueda en todos los nodos para datos completos.
Índice
Es una colección de diferentes tipos de documentos y sus propiedades. Index también utiliza el concepto de fragmentos para mejorar el rendimiento. Por ejemplo, un conjunto de documentos contiene datos de una aplicación de red social.
Documento
Es una colección de campos de una manera específica definida en formato JSON. Cada documento pertenece a un tipo y reside dentro de un índice. Cada documento está asociado con un identificador único llamado UID.
Casco
Los índices se subdividen horizontalmente en fragmentos. Esto significa que cada fragmento contiene todas las propiedades del documento, pero contiene menos cantidad de objetos JSON que índice. La separación horizontal hace que el fragmento sea un nodo independiente, que se puede almacenar en cualquier nodo. El fragmento primario es la parte horizontal original de un índice y luego estos fragmentos primarios se replican en fragmentos de réplica.
Réplicas
Elasticsearch permite al usuario crear réplicas de sus índices y fragmentos. La replicación no solo ayuda a aumentar la disponibilidad de datos en caso de falla, sino que también mejora el rendimiento de la búsqueda al realizar una operación de búsqueda paralela en estas réplicas.
Ventajas
Elasticsearch está desarrollado en Java, lo que lo hace compatible en casi todas las plataformas.
Elasticsearch es en tiempo real, en otras palabras, después de un segundo, el documento agregado se puede buscar en este motor.
Elasticsearch está distribuido, lo que facilita la ampliación e integración en cualquier gran organización.
La creación de copias de seguridad completas es fácil utilizando el concepto de puerta de enlace, que está presente en Elasticsearch.
Manejar la tenencia múltiple es muy fácil en Elasticsearch en comparación con Apache Solr.
Elasticsearch utiliza objetos JSON como respuestas, lo que hace posible invocar el servidor Elasticsearch con una gran cantidad de lenguajes de programación diferentes.
Elasticsearch admite casi todos los tipos de documentos, excepto aquellos que no admiten la representación de texto.
Desventajas
Elasticsearch no tiene soporte en varios idiomas en términos de manejo de datos de solicitud y respuesta (solo es posible en JSON) a diferencia de Apache Solr, donde es posible en formatos CSV, XML y JSON.
Ocasionalmente, Elasticsearch tiene un problema de situaciones de cerebro dividido.
Comparación entre Elasticsearch y RDBMS
En Elasticsearch, el índice es similar a las tablas en RDBMS (Relation Database Management System). Cada tabla es una colección de filas, al igual que cada índice es una colección de documentos en Elasticsearch.
La siguiente tabla ofrece una comparación directa entre estos términos.
Elasticsearch | RDBMS |
---|---|
Racimo | Base de datos |
Casco | Casco |
Índice | Mesa |
Campo | Columna |
Documento | Fila |
En este capítulo, comprenderemos el procedimiento de instalación de Elasticsearch en detalle.
Para instalar Elasticsearch en su computadora local, deberá seguir los pasos que se detallan a continuación:
Step 1- Verifique la versión de java instalada en su computadora. Debería ser Java 7 o superior. Puede verificar haciendo lo siguiente:
En el sistema operativo (SO) Windows (mediante el símbolo del sistema):
> java -version
En SO UNIX (usando terminal) -
$ echo $JAVA_HOME
Step 2 - Dependiendo de su sistema operativo, descargue Elasticsearch de www.elastic.co como se menciona a continuación -
Para el sistema operativo Windows, descargue el archivo ZIP.
Para el sistema operativo UNIX, descargue el archivo TAR.
Para el sistema operativo Debian, descargue el archivo DEB.
Para Red Hat y otras distribuciones de Linux, descargue el archivo RPN.
Las utilidades APT y Yum también se pueden utilizar para instalar Elasticsearch en muchas distribuciones de Linux.
Step 3 - El proceso de instalación de Elasticsearch es simple y se describe a continuación para diferentes sistemas operativos -
Windows OS- Descomprima el paquete zip y se instalará Elasticsearch.
UNIX OS- Extraiga el archivo tar en cualquier ubicación y se instalará Elasticsearch.
$wget https://artifacts.elastic.co/downloads/elasticsearch/elasticsearch7.0.0-linux-x86_64.tar.gz $tar -xzf elasticsearch-7.0.0-linux-x86_64.tar.gz
Using APT utility for Linux OS- Descargue e instale la clave de firma pública
$ wget -qo - https://artifacts.elastic.co/GPG-KEY-elasticsearch | sudo
apt-key add -
Guarde la definición del repositorio como se muestra a continuación:
$ echo "deb https://artifacts.elastic.co/packages/7.x/apt stable main" |
sudo tee -a /etc/apt/sources.list.d/elastic-7.x.list
Ejecute la actualización usando el siguiente comando:
$ sudo apt-get update
Ahora puede instalar usando el siguiente comando:
$ sudo apt-get install elasticsearch
Download and install the Debian package manually using the command given here −
$wget https://artifacts.elastic.co/downloads/elasticsearch/elasticsearch7.0.0-amd64.deb $sudo dpkg -i elasticsearch-7.0.0-amd64.deb0
Using YUM utility for Debian Linux OS
Descargue e instale la clave de firma pública -
$ rpm --import https://artifacts.elastic.co/GPG-KEY-elasticsearch
AÑADA el siguiente texto en el archivo con el sufijo .repo en su directorio “/etc/yum.repos.d/”. Por ejemplo, elasticsearch.repo
elasticsearch-7.x]
name=Elasticsearch repository for 7.x packages
baseurl=https://artifacts.elastic.co/packages/7.x/yum
gpgcheck=1
gpgkey=https://artifacts.elastic.co/GPG-KEY-elasticsearch
enabled=1
autorefresh=1
type=rpm-md
Ahora puede instalar Elasticsearch usando el siguiente comando
sudo yum install elasticsearch
Step 4- Vaya al directorio de inicio de Elasticsearch y dentro de la carpeta bin. Ejecute el archivo elasticsearch.bat en el caso de Windows o puede hacer lo mismo usando el símbolo del sistema y a través de la terminal en el caso del archivo Elasticsearch de ron UNIX.
En Windows
> cd elasticsearch-2.1.0/bin
> elasticsearch
En Linux
$ cd elasticsearch-2.1.0/bin
$ ./elasticsearch
Note - En el caso de Windows, es posible que obtenga un error que indique que JAVA_HOME no está configurado, configúrelo en las variables de entorno en “C: \ Archivos de programa \ Java \ jre1.8.0_31” o la ubicación donde instaló java.
Step 5- El puerto predeterminado para la interfaz web Elasticsearch es 9200 o puede cambiarlo cambiando http.port dentro del archivo elasticsearch.yml presente en el directorio bin. Puede comprobar si el servidor está en funcionamiento navegandohttp://localhost:9200. Devolverá un objeto JSON, que contiene la información sobre el Elasticsearch instalado de la siguiente manera:
{
"name" : "Brain-Child",
"cluster_name" : "elasticsearch", "version" : {
"number" : "2.1.0",
"build_hash" : "72cd1f1a3eee09505e036106146dc1949dc5dc87",
"build_timestamp" : "2015-11-18T22:40:03Z",
"build_snapshot" : false,
"lucene_version" : "5.3.1"
},
"tagline" : "You Know, for Search"
}
Step 6- En este paso, instalemos Kibana. Siga el código respectivo que se proporciona a continuación para instalar en Linux y Windows:
For Installation on Linux −
wget https://artifacts.elastic.co/downloads/kibana/kibana-7.0.0-linuxx86_64.tar.gz
tar -xzf kibana-7.0.0-linux-x86_64.tar.gz
cd kibana-7.0.0-linux-x86_64/
./bin/kibana
For Installation on Windows −
Descargue Kibana para Windows desde https://www.elastic.co/products/kibana. Una vez que haga clic en el enlace, encontrará la página de inicio como se muestra a continuación:
Descomprima y vaya al directorio de inicio de Kibana y luego ejecútelo.
CD c:\kibana-7.0.0-windows-x86_64
.\bin\kibana.bat
En este capítulo, aprendamos cómo agregar algunos índices, mapas y datos a Elasticsearch. Tenga en cuenta que algunos de estos datos se utilizarán en los ejemplos explicados en este tutorial.
Crear índice
Puede usar el siguiente comando para crear un índice:
PUT school
Respuesta
Si se crea el índice, puede ver el siguiente resultado:
{"acknowledged": true}
Agregar datos
Elasticsearch almacenará los documentos que agreguemos al índice como se muestra en el siguiente código. Los documentos reciben algunas identificaciones que se utilizan para identificar el documento.
Cuerpo de solicitud
POST school/_doc/10
{
"name":"Saint Paul School", "description":"ICSE Afiliation",
"street":"Dawarka", "city":"Delhi", "state":"Delhi", "zip":"110075",
"location":[28.5733056, 77.0122136], "fees":5000,
"tags":["Good Faculty", "Great Sports"], "rating":"4.5"
}
Respuesta
{
"_index" : "school",
"_type" : "_doc",
"_id" : "10",
"_version" : 1,
"result" : "created",
"_shards" : {
"total" : 2,
"successful" : 1,
"failed" : 0
},
"_seq_no" : 2,
"_primary_term" : 1
}
Aquí, estamos agregando otro documento similar.
POST school/_doc/16
{
"name":"Crescent School", "description":"State Board Affiliation",
"street":"Tonk Road",
"city":"Jaipur", "state":"RJ", "zip":"176114","location":[26.8535922,75.7923988],
"fees":2500, "tags":["Well equipped labs"], "rating":"4.5"
}
Respuesta
{
"_index" : "school",
"_type" : "_doc",
"_id" : "16",
"_version" : 1,
"result" : "created",
"_shards" : {
"total" : 2,
"successful" : 1,
"failed" : 0
},
"_seq_no" : 9,
"_primary_term" : 7
}
De esta manera, seguiremos agregando cualquier dato de ejemplo que necesitemos para nuestro trabajo en los próximos capítulos.
Agregar datos de muestra en Kibana
Kibana es una herramienta basada en GUI para acceder a los datos y crear la visualización. En esta sección, entendamos cómo podemos agregarle datos de muestra.
En la página de inicio de Kibana, elija la siguiente opción para agregar datos de comercio electrónico de muestra:
La siguiente pantalla mostrará alguna visualización y un botón para Agregar datos:
Al hacer clic en Agregar datos, se mostrará la siguiente pantalla que confirma que los datos se han agregado a un índice llamado eCommerce.
En cualquier sistema o software, cuando estamos actualizando a una versión más nueva, necesitamos seguir algunos pasos para mantener la configuración de la aplicación, los datos y otras cosas. Estos pasos son necesarios para que la aplicación sea estable en el nuevo sistema o para mantener la integridad de los datos (evitar que los datos se corrompan).
Debe seguir los siguientes pasos para actualizar Elasticsearch:
Leer los documentos de actualización de https://www.elastic.co/
Pruebe la versión mejorada en sus entornos que no son de producción, como en entornos UAT, E2E, SIT o DEV.
Tenga en cuenta que no es posible volver a la versión anterior de Elasticsearch sin una copia de seguridad de los datos. Por lo tanto, se recomienda una copia de seguridad de los datos antes de actualizar a una versión superior.
Podemos actualizar usando el reinicio completo del clúster o la actualización continua. La actualización progresiva es para nuevas versiones. Tenga en cuenta que no hay interrupción del servicio cuando utiliza el método de actualización continua para la migración.
Pasos para la actualización
Pruebe la actualización en un entorno de desarrollo antes de actualizar su clúster de producción.
Haga una copia de seguridad de sus datos. No puede volver a una versión anterior a menos que tenga una instantánea de sus datos.
Considere cerrar los trabajos de aprendizaje automático antes de comenzar el proceso de actualización. Si bien los trabajos de aprendizaje automático pueden continuar ejecutándose durante una actualización progresiva, aumenta la sobrecarga en el clúster durante el proceso de actualización.
Actualice los componentes de su Elastic Stack en el siguiente orden:
- Elasticsearch
- Kibana
- Logstash
- Beats
- Servidor APM
Actualización de 6.6 o anterior
Para actualizar directamente a Elasticsearch 7.1.0 desde las versiones 6.0-6.6, debe volver a indexar manualmente cualquier índice 5.x que necesite transferir y realizar un reinicio completo del clúster.
Reinicio completo del clúster
El proceso de reinicio completo del clúster implica apagar cada nodo del clúster, actualizar cada nodo a 7x y luego reiniciar el clúster.
Los siguientes son los pasos de alto nivel que deben llevarse a cabo para el reinicio completo del clúster:
- Deshabilitar la asignación de fragmentos
- Detenga la indexación y realice una descarga sincronizada
- Apagar todos los nodos
- Actualizar todos los nodos
- Actualiza cualquier complemento
- Inicie cada nodo actualizado
- Espere a que todos los nodos se unan al clúster y notifiquen un estado de color amarillo
- Volver a habilitar la asignación
Una vez que se vuelve a habilitar la asignación, el clúster comienza a asignar los fragmentos de réplica a los nodos de datos. En este punto, es seguro reanudar la indexación y la búsqueda, pero su clúster se recuperará más rápidamente si puede esperar hasta que todos los fragmentos primarios y de réplica se hayan asignado correctamente y el estado de todos los nodos sea verde.
La interfaz de programación de aplicaciones (API) en la web es un grupo de llamadas a funciones u otras instrucciones de programación para acceder al componente de software en esa aplicación web en particular. Por ejemplo, la API de Facebook ayuda a un desarrollador a crear aplicaciones accediendo a datos u otras funcionalidades de Facebook; puede ser fecha de nacimiento o actualización de estado.
Elasticsearch proporciona una API REST, a la que se accede mediante JSON a través de HTTP. Elasticsearch usa algunas convenciones que discutiremos ahora.
Múltiples índices
La mayoría de las operaciones, principalmente búsquedas y otras operaciones, en las API son para uno o más índices. Esto ayuda al usuario a buscar en varios lugares o en todos los datos disponibles con solo ejecutar una consulta una vez. Se utilizan muchas notaciones diferentes para realizar operaciones en múltiples índices. Discutiremos algunos de ellos aquí en este capítulo.
Notación separada por comas
POST /index1,index2,index3/_search
Cuerpo de solicitud
{
"query":{
"query_string":{
"query":"any_string"
}
}
}
Respuesta
Objetos JSON de index1, index2, index3 que tienen any_string.
_all Palabra clave para todos los índices
POST /_all/_search
Cuerpo de solicitud
{
"query":{
"query_string":{
"query":"any_string"
}
}
}
Respuesta
Objetos JSON de todos los índices y que tengan any_string.
Comodines (*, +, -)
POST /school*/_search
Cuerpo de solicitud
{
"query":{
"query_string":{
"query":"CBSE"
}
}
}
Respuesta
Objetos JSON de todos los índices que comienzan con la escuela que tiene CBSE.
Alternativamente, también puede usar el siguiente código:
POST /school*,-schools_gov /_search
Cuerpo de solicitud
{
"query":{
"query_string":{
"query":"CBSE"
}
}
}
Respuesta
Objetos JSON de todos los índices que comienzan con "school" pero no de schools_gov y tienen CBSE.
También hay algunos parámetros de cadena de consulta de URL:
- ignore_unavailable- No ocurrirá ningún error o no se detendrá ninguna operación, si uno o más índices presentes en la URL no existen. Por ejemplo, existe un índice de escuelas, pero no existe book_shops.
POST /school*,book_shops/_search
Cuerpo de solicitud
{
"query":{
"query_string":{
"query":"CBSE"
}
}
}
Cuerpo de solicitud
{
"error":{
"root_cause":[{
"type":"index_not_found_exception", "reason":"no such index",
"resource.type":"index_or_alias", "resource.id":"book_shops",
"index":"book_shops"
}],
"type":"index_not_found_exception", "reason":"no such index",
"resource.type":"index_or_alias", "resource.id":"book_shops",
"index":"book_shops"
},"status":404
}
Considere el siguiente código:
POST /school*,book_shops/_search?ignore_unavailable = true
Cuerpo de solicitud
{
"query":{
"query_string":{
"query":"CBSE"
}
}
}
Respuesta (sin error)
Objetos JSON de todos los índices que comienzan con la escuela que tiene CBSE.
allow_no_indices
trueEl valor de este parámetro evitará errores, si una URL con comodines no da como resultado índices. Por ejemplo, no hay un índice que comience con schools_pri -
POST /schools_pri*/_search?allow_no_indices = true
Cuerpo de solicitud
{
"query":{
"match_all":{}
}
}
Respuesta (sin errores)
{
"took":1,"timed_out": false, "_shards":{"total":0, "successful":0, "failed":0},
"hits":{"total":0, "max_score":0.0, "hits":[]}
}
expand_wildcards
Este parámetro decide si los comodines deben expandirse a índices abiertos o índices cerrados o realizar ambos. El valor de este parámetro puede ser abierto y cerrado o ninguno y todos.
Por ejemplo, cerrar escuelas indexadas:
POST /schools/_close
Respuesta
{"acknowledged":true}
Considere el siguiente código:
POST /school*/_search?expand_wildcards = closed
Cuerpo de solicitud
{
"query":{
"match_all":{}
}
}
Respuesta
{
"error":{
"root_cause":[{
"type":"index_closed_exception", "reason":"closed", "index":"schools"
}],
"type":"index_closed_exception", "reason":"closed", "index":"schools"
}, "status":403
}
Soporte matemático de fechas en nombres de índices
Elasticsearch ofrece una funcionalidad para buscar índices según fecha y hora. Necesitamos especificar la fecha y la hora en un formato específico. Por ejemplo, accountdetail-2015.12.30, index almacenará los detalles de la cuenta bancaria del 30 de diciembre de 2015. Se pueden realizar operaciones matemáticas para obtener detalles para una fecha en particular o un rango de fecha y hora.
Formato para el nombre del índice matemático de fecha -
<static_name{date_math_expr{date_format|time_zone}}>
/<accountdetail-{now-2d{YYYY.MM.dd|utc}}>/_search
static_name es una parte de la expresión que permanece igual en todos los índices matemáticos de fecha, como el detalle de la cuenta. date_math_expr contiene la expresión matemática que determina la fecha y la hora dinámicamente como ahora-2d. date_format contiene el formato en el que se escribe la fecha en un índice como YYYY.MM.dd. Si la fecha de hoy es el 30 de diciembre de 2015, <accountdetail- {now-2d {YYYY.MM.dd}}> devolverá accountdetail-2015.12.28.
Expresión | Resuelve |
---|---|
<accountdetail- {ahora-d}> | accountdetail-2015.12.29 |
<accountdetail- {ahora-M}> | accountdetail-2015.11.30 |
<accountdetail- {ahora {YYYY.MM}}> | accountdetail-2015.12 |
Ahora veremos algunas de las opciones comunes disponibles en Elasticsearch que se pueden usar para obtener la respuesta en un formato específico.
Bonitos resultados
Podemos obtener respuesta en un objeto JSON bien formateado simplemente agregando un parámetro de consulta de URL, es decir, pretty = true.
POST /schools/_search?pretty = true
Cuerpo de solicitud
{
"query":{
"match_all":{}
}
}
Respuesta
……………………..
{
"_index" : "schools", "_type" : "school", "_id" : "1", "_score" : 1.0,
"_source":{
"name":"Central School", "description":"CBSE Affiliation",
"street":"Nagan", "city":"paprola", "state":"HP", "zip":"176115",
"location": [31.8955385, 76.8380405], "fees":2000,
"tags":["Senior Secondary", "beautiful campus"], "rating":"3.5"
}
}
………………….
Salida legible por humanos
Esta opción puede cambiar las respuestas estadísticas a una forma legible por humanos (si humano = verdadero) o una forma legible por computadora (si humano = falso). Por ejemplo, si humano = verdadero, distancia_kilómetro = 20KM y si humano = falso, distancia_metro = 20000, cuando la respuesta deba ser utilizada por otro programa de computadora.
Filtrado de respuestas
Podemos filtrar la respuesta a menos campos agregándolos en el parámetro field_path. Por ejemplo,
POST /schools/_search?filter_path = hits.total
Cuerpo de solicitud
{
"query":{
"match_all":{}
}
}
Respuesta
{"hits":{"total":3}}
Elasticsearch proporciona API de un solo documento y API de varios documentos, donde la llamada a la API se dirige a un solo documento y a varios documentos, respectivamente.
API de índice
Ayuda a agregar o actualizar el documento JSON en un índice cuando se realiza una solicitud a ese índice respectivo con una asignación específica. Por ejemplo, la siguiente solicitud agregará el objeto JSON a las escuelas indexadas y en el mapeo de escuelas:
PUT schools/_doc/5
{
name":"City School", "description":"ICSE", "street":"West End",
"city":"Meerut",
"state":"UP", "zip":"250002", "location":[28.9926174, 77.692485],
"fees":3500,
"tags":["fully computerized"], "rating":"4.5"
}
Al ejecutar el código anterior, obtenemos el siguiente resultado:
{
"_index" : "schools",
"_type" : "_doc",
"_id" : "5",
"_version" : 1,
"result" : "created",
"_shards" : {
"total" : 2,
"successful" : 1,
"failed" : 0
},
"_seq_no" : 2,
"_primary_term" : 1
}
Creación automática de índices
Cuando se realiza una solicitud para agregar un objeto JSON a un índice en particular y si ese índice no existe, esta API crea automáticamente ese índice y también la asignación subyacente para ese objeto JSON en particular. Esta funcionalidad se puede desactivar cambiando los valores de los siguientes parámetros a falso, que están presentes en el archivo elasticsearch.yml.
action.auto_create_index:false
index.mapper.dynamic:false
También puede restringir la creación automática de índice, donde solo se permite el nombre del índice con patrones específicos cambiando el valor del siguiente parámetro:
action.auto_create_index:+acc*,-bank*
Note - Aquí + indica permitido y - indica no permitido.
Control de versiones
Elasticsearch también proporciona una función de control de versiones. Podemos usar un parámetro de consulta de versión para especificar la versión de un documento en particular.
PUT schools/_doc/5?version=7&version_type=external
{
"name":"Central School", "description":"CBSE Affiliation", "street":"Nagan",
"city":"paprola", "state":"HP", "zip":"176115", "location":[31.8955385, 76.8380405],
"fees":2200, "tags":["Senior Secondary", "beautiful campus"], "rating":"3.3"
}
Al ejecutar el código anterior, obtenemos el siguiente resultado:
{
"_index" : "schools",
"_type" : "_doc",
"_id" : "5",
"_version" : 7,
"result" : "updated",
"_shards" : {
"total" : 2,
"successful" : 1,
"failed" : 0
},
"_seq_no" : 3,
"_primary_term" : 1
}
El control de versiones es un proceso en tiempo real y no se ve afectado por las operaciones de búsqueda en tiempo real.
Hay dos tipos más importantes de control de versiones:
Versiones internas
El control de versiones interno es la versión predeterminada que comienza con 1 y se incrementa con cada actualización, incluidas las eliminaciones.
Versiones externas
Se utiliza cuando el control de versiones de los documentos se almacena en un sistema externo como sistemas de control de versiones de terceros. Para habilitar esta funcionalidad, necesitamos establecer version_type en external. Aquí Elasticsearch almacenará el número de versión designado por el sistema externo y no los incrementará automáticamente.
Tipo de operación
El tipo de operación se usa para forzar una operación de creación. Esto ayuda a evitar la sobrescritura de documentos existentes.
PUT chapter/_doc/1?op_type=create
{
"Text":"this is chapter one"
}
Al ejecutar el código anterior, obtenemos el siguiente resultado:
{
"_index" : "chapter",
"_type" : "_doc",
"_id" : "1",
"_version" : 1,
"result" : "created",
"_shards" : {
"total" : 2,
"successful" : 1,
"failed" : 0
},
"_seq_no" : 0,
"_primary_term" : 1
}
Generación automática de ID
Cuando no se especifica el ID en la operación de índice, Elasticsearch genera automáticamente el ID para ese documento.
POST chapter/_doc/
{
"user" : "tpoint",
"post_date" : "2018-12-25T14:12:12",
"message" : "Elasticsearch Tutorial"
}
Al ejecutar el código anterior, obtenemos el siguiente resultado:
{
"_index" : "chapter",
"_type" : "_doc",
"_id" : "PVghWGoB7LiDTeV6LSGu",
"_version" : 1,
"result" : "created",
"_shards" : {
"total" : 2,
"successful" : 1,
"failed" : 0
},
"_seq_no" : 1,
"_primary_term" : 1
}
Obtener API
La API ayuda a extraer un objeto JSON de tipo mediante la realización de una solicitud de obtención para un documento en particular.
pre class="prettyprint notranslate" > GET schools/_doc/5
Al ejecutar el código anterior, obtenemos el siguiente resultado:
{
"_index" : "schools",
"_type" : "_doc",
"_id" : "5",
"_version" : 7,
"_seq_no" : 3,
"_primary_term" : 1,
"found" : true,
"_source" : {
"name" : "Central School",
"description" : "CBSE Affiliation",
"street" : "Nagan",
"city" : "paprola",
"state" : "HP",
"zip" : "176115",
"location" : [
31.8955385,
76.8380405
],
"fees" : 2200,
"tags" : [
"Senior Secondary",
"beautiful campus"
],
"rating" : "3.3"
}
}
Esta operación es en tiempo real y no se ve afectada por la frecuencia de actualización de Index.
También puede especificar la versión, luego Elasticsearch buscará solo esa versión del documento.
También puede especificar _all en la solicitud, de modo que Elasticsearch pueda buscar ese ID de documento en cada tipo y devolverá el primer documento coincidente.
También puede especificar los campos que desee en su resultado de ese documento en particular.
GET schools/_doc/5?_source_includes=name,fees
Al ejecutar el código anterior, obtenemos el siguiente resultado:
{
"_index" : "schools",
"_type" : "_doc",
"_id" : "5",
"_version" : 7,
"_seq_no" : 3,
"_primary_term" : 1,
"found" : true,
"_source" : {
"fees" : 2200,
"name" : "Central School"
}
}
También puede obtener la parte de origen en su resultado simplemente agregando _source part en su solicitud de obtención.
GET schools/_doc/5?_source
Al ejecutar el código anterior, obtenemos el siguiente resultado:
{
"_index" : "schools",
"_type" : "_doc",
"_id" : "5",
"_version" : 7,
"_seq_no" : 3,
"_primary_term" : 1,
"found" : true,
"_source" : {
"name" : "Central School",
"description" : "CBSE Affiliation",
"street" : "Nagan",
"city" : "paprola",
"state" : "HP",
"zip" : "176115",
"location" : [
31.8955385,
76.8380405
],
"fees" : 2200,
"tags" : [
"Senior Secondary",
"beautiful campus"
],
"rating" : "3.3"
}
}
También puede actualizar el fragmento antes de realizar la operación de obtención si establece el parámetro de actualización en verdadero.
Eliminar API
Puede eliminar un índice, mapeo o documento en particular enviando una solicitud HTTP DELETE a Elasticsearch.
DELETE schools/_doc/4
Al ejecutar el código anterior, obtenemos el siguiente resultado:
{
"found":true, "_index":"schools", "_type":"school", "_id":"4", "_version":2,
"_shards":{"total":2, "successful":1, "failed":0}
}
Se puede especificar la versión del documento para eliminar esa versión en particular. El parámetro de enrutamiento se puede especificar para eliminar el documento de un usuario en particular y la operación falla si el documento no pertenece a ese usuario en particular. En esta operación, puede especificar la opción de actualización y tiempo de espera igual que GET API.
Actualizar API
El script se usa para realizar esta operación y el control de versiones se usa para asegurarse de que no se hayan realizado actualizaciones durante la obtención y reindexación. Por ejemplo, puede actualizar las tarifas de la escuela usando script -
POST schools/_update/4
{
"script" : {
"source": "ctx._source.name = params.sname",
"lang": "painless",
"params" : {
"sname" : "City Wise School"
}
}
}
Al ejecutar el código anterior, obtenemos el siguiente resultado:
{
"_index" : "schools",
"_type" : "_doc",
"_id" : "4",
"_version" : 3,
"result" : "updated",
"_shards" : {
"total" : 2,
"successful" : 1,
"failed" : 0
},
"_seq_no" : 4,
"_primary_term" : 2
}
Puede verificar la actualización enviando una solicitud de obtención al documento actualizado.
Esta API se utiliza para buscar contenido en Elasticsearch. Un usuario puede buscar enviando una solicitud de obtención con una cadena de consulta como parámetro o puede publicar una consulta en el cuerpo del mensaje de la solicitud de publicación. Básicamente, todos los APIS de búsqueda son de múltiples índices y múltiples tipos.
Multi-índice
Elasticsearch nos permite buscar los documentos presentes en todos los índices o en algunos índices específicos. Por ejemplo, si necesitamos buscar todos los documentos con un nombre que contenga central, podemos hacer lo que se muestra aquí -
GET /_all/_search?q=city:paprola
Al ejecutar el código anterior, obtenemos la siguiente respuesta:
{
"took" : 33,
"timed_out" : false,
"_shards" : {
"total" : 7,
"successful" : 7,
"skipped" : 0,
"failed" : 0
},
"hits" : {
"total" : {
"value" : 1,
"relation" : "eq"
},
"max_score" : 0.9808292,
"hits" : [
{
"_index" : "schools",
"_type" : "school",
"_id" : "5",
"_score" : 0.9808292,
"_source" : {
"name" : "Central School",
"description" : "CBSE Affiliation",
"street" : "Nagan",
"city" : "paprola",
"state" : "HP",
"zip" : "176115",
"location" : [
31.8955385,
76.8380405
],
"fees" : 2200,
"tags" : [
"Senior Secondary",
"beautiful campus"
],
"rating" : "3.3"
}
}
]
}
}
Búsqueda de URI
Se pueden pasar muchos parámetros en una operación de búsqueda utilizando el identificador uniforme de recursos:
S. No | Descripción de parámetros |
---|---|
1 | Q Este parámetro se utiliza para especificar la cadena de consulta. |
2 | lenient Este parámetro se usa para especificar la cadena de consulta. Los errores basados en formato se pueden ignorar simplemente estableciendo este parámetro en verdadero. Es falso por defecto. |
3 | fields Este parámetro se utiliza para especificar la cadena de consulta. |
4 | sort Podemos obtener un resultado ordenado usando este parámetro, los valores posibles para este parámetro son fieldName, fieldName: asc / fieldname: desc |
5 | timeout Podemos restringir el tiempo de búsqueda usando este parámetro y la respuesta solo contiene los aciertos en ese tiempo especificado. De forma predeterminada, no hay tiempo de espera. |
6 | terminate_after Podemos restringir la respuesta a un número específico de documentos para cada fragmento, una vez alcanzado, la consulta terminará antes. De forma predeterminada, no hay terminate_after. |
7 | from El índice de partida de los hits a devolver. El valor predeterminado es 0. |
8 | size Denota el número de hits que se devolverán. El valor predeterminado es 10. |
Solicitar búsqueda de cuerpo
También podemos especificar la consulta usando la consulta DSL en el cuerpo de la solicitud y ya se han dado muchos ejemplos en capítulos anteriores. Aquí se da un ejemplo:
POST /schools/_search
{
"query":{
"query_string":{
"query":"up"
}
}
}
Al ejecutar el código anterior, obtenemos la siguiente respuesta:
{
"took" : 11,
"timed_out" : false,
"_shards" : {
"total" : 1,
"successful" : 1,
"skipped" : 0,
"failed" : 0
},
"hits" : {
"total" : {
"value" : 1,
"relation" : "eq"
},
"max_score" : 0.47000363,
"hits" : [
{
"_index" : "schools",
"_type" : "school",
"_id" : "4",
"_score" : 0.47000363,
"_source" : {
"name" : "City Best School",
"description" : "ICSE",
"street" : "West End",
"city" : "Meerut",
"state" : "UP",
"zip" : "250002",
"location" : [
28.9926174,
77.692485
],
"fees" : 3500,
"tags" : [
"fully computerized"
],
"rating" : "4.5"
}
}
]
}
}
El marco de agregaciones recopila todos los datos seleccionados por la consulta de búsqueda y consta de muchos componentes básicos, que ayudan a crear resúmenes complejos de los datos. La estructura básica de una agregación se muestra aquí:
"aggregations" : {
"" : {
"" : {
}
[,"meta" : { [] } ]?
[,"aggregations" : { []+ } ]?
}
[,"" : { ... } ]*
}
Existen diferentes tipos de agregaciones, cada una con su propio propósito. Se tratan en detalle en este capítulo.
Agregaciones de métricas
Estas agregaciones ayudan a calcular matrices a partir de los valores de campo de los documentos agregados y, en ocasiones, se pueden generar algunos valores a partir de scripts.
Las matrices numéricas son de un solo valor como agregación promedio o de múltiples valores como estadísticas.
Agregación promedio
Esta agregación se utiliza para obtener el promedio de cualquier campo numérico presente en los documentos agregados. Por ejemplo,
POST /schools/_search
{
"aggs":{
"avg_fees":{"avg":{"field":"fees"}}
}
}
Al ejecutar el código anterior, obtenemos el siguiente resultado:
{
"took" : 41,
"timed_out" : false,
"_shards" : {
"total" : 1,
"successful" : 1,
"skipped" : 0,
"failed" : 0
},
"hits" : {
"total" : {
"value" : 2,
"relation" : "eq"
},
"max_score" : 1.0,
"hits" : [
{
"_index" : "schools",
"_type" : "school",
"_id" : "5",
"_score" : 1.0,
"_source" : {
"name" : "Central School",
"description" : "CBSE Affiliation",
"street" : "Nagan",
"city" : "paprola",
"state" : "HP",
"zip" : "176115",
"location" : [
31.8955385,
76.8380405
],
"fees" : 2200,
"tags" : [
"Senior Secondary",
"beautiful campus"
],
"rating" : "3.3"
}
},
{
"_index" : "schools",
"_type" : "school",
"_id" : "4",
"_score" : 1.0,
"_source" : {
"name" : "City Best School",
"description" : "ICSE",
"street" : "West End",
"city" : "Meerut",
"state" : "UP",
"zip" : "250002",
"location" : [
28.9926174,
77.692485
],
"fees" : 3500,
"tags" : [
"fully computerized"
],
"rating" : "4.5"
}
}
]
},
"aggregations" : {
"avg_fees" : {
"value" : 2850.0
}
}
}
Agregación de cardinalidad
Esta agregación da el recuento de valores distintos de un campo en particular.
POST /schools/_search?size=0
{
"aggs":{
"distinct_name_count":{"cardinality":{"field":"fees"}}
}
}
Al ejecutar el código anterior, obtenemos el siguiente resultado:
{
"took" : 2,
"timed_out" : false,
"_shards" : {
"total" : 1,
"successful" : 1,
"skipped" : 0,
"failed" : 0
},
"hits" : {
"total" : {
"value" : 2,
"relation" : "eq"
},
"max_score" : null,
"hits" : [ ]
},
"aggregations" : {
"distinct_name_count" : {
"value" : 2
}
}
}
Note - El valor de cardinalidad es 2 porque hay dos valores distintos en las tarifas.
Agregación de estadísticas extendida
Esta agregación genera todas las estadísticas sobre un campo numérico específico en documentos agregados.
POST /schools/_search?size=0
{
"aggs" : {
"fees_stats" : { "extended_stats" : { "field" : "fees" } }
}
}
Al ejecutar el código anterior, obtenemos el siguiente resultado:
{
"took" : 8,
"timed_out" : false,
"_shards" : {
"total" : 1,
"successful" : 1,
"skipped" : 0,
"failed" : 0
},
"hits" : {
"total" : {
"value" : 2,
"relation" : "eq"
},
"max_score" : null,
"hits" : [ ]
},
"aggregations" : {
"fees_stats" : {
"count" : 2,
"min" : 2200.0,
"max" : 3500.0,
"avg" : 2850.0,
"sum" : 5700.0,
"sum_of_squares" : 1.709E7,
"variance" : 422500.0,
"std_deviation" : 650.0,
"std_deviation_bounds" : {
"upper" : 4150.0,
"lower" : 1550.0
}
}
}
}
Agregación máxima
Esta agregación encuentra el valor máximo de un campo numérico específico en documentos agregados.
POST /schools/_search?size=0
{
"aggs" : {
"max_fees" : { "max" : { "field" : "fees" } }
}
}
Al ejecutar el código anterior, obtenemos el siguiente resultado:
{
"took" : 16,
"timed_out" : false,
"_shards" : {
"total" : 1,
"successful" : 1,
"skipped" : 0,
"failed" : 0
},
"hits" : {
"total" : {
"value" : 2,
"relation" : "eq"
},
"max_score" : null,
"hits" : [ ]
},
"aggregations" : {
"max_fees" : {
"value" : 3500.0
}
}
}
Agregación mínima
Esta agregación encuentra el valor mínimo de un campo numérico específico en documentos agregados.
POST /schools/_search?size=0
{
"aggs" : {
"min_fees" : { "min" : { "field" : "fees" } }
}
}
Al ejecutar el código anterior, obtenemos el siguiente resultado:
{
"took" : 2,
"timed_out" : false,
"_shards" : {
"total" : 1,
"successful" : 1,
"skipped" : 0,
"failed" : 0
},
"hits" : {
"total" : {
"value" : 2,
"relation" : "eq"
},
"max_score" : null,
"hits" : [ ]
},
"aggregations" : {
"min_fees" : {
"value" : 2200.0
}
}
}
Agregación de suma
Esta agregación calcula la suma de un campo numérico específico en documentos agregados.
POST /schools/_search?size=0
{
"aggs" : {
"total_fees" : { "sum" : { "field" : "fees" } }
}
}
Al ejecutar el código anterior, obtenemos el siguiente resultado:
{
"took" : 8,
"timed_out" : false,
"_shards" : {
"total" : 1,
"successful" : 1,
"skipped" : 0,
"failed" : 0
},
"hits" : {
"total" : {
"value" : 2,
"relation" : "eq"
},
"max_score" : null,
"hits" : [ ]
},
"aggregations" : {
"total_fees" : {
"value" : 5700.0
}
}
}
Hay algunas otras agregaciones de métricas que se utilizan en casos especiales como la agregación de límites geográficos y la agregación de geocentroide con el propósito de la ubicación geográfica.
Agregaciones de estadísticas
Una agregación de métricas de varios valores que calcula estadísticas sobre valores numéricos extraídos de los documentos agregados.
POST /schools/_search?size=0
{
"aggs" : {
"grades_stats" : { "stats" : { "field" : "fees" } }
}
}
Al ejecutar el código anterior, obtenemos el siguiente resultado:
{
"took" : 2,
"timed_out" : false,
"_shards" : {
"total" : 1,
"successful" : 1,
"skipped" : 0,
"failed" : 0
},
"hits" : {
"total" : {
"value" : 2,
"relation" : "eq"
},
"max_score" : null,
"hits" : [ ]
},
"aggregations" : {
"grades_stats" : {
"count" : 2,
"min" : 2200.0,
"max" : 3500.0,
"avg" : 2850.0,
"sum" : 5700.0
}
}
}
Metadatos de agregación
Puede agregar algunos datos sobre la agregación en el momento de la solicitud utilizando una metaetiqueta y puede obtenerlos como respuesta.
POST /schools/_search?size=0
{
"aggs" : {
"min_fees" : { "avg" : { "field" : "fees" } ,
"meta" :{
"dsc" :"Lowest Fees This Year"
}
}
}
}
Al ejecutar el código anterior, obtenemos el siguiente resultado:
{
"took" : 0,
"timed_out" : false,
"_shards" : {
"total" : 1,
"successful" : 1,
"skipped" : 0,
"failed" : 0
},
"hits" : {
"total" : {
"value" : 2,
"relation" : "eq"
},
"max_score" : null,
"hits" : [ ]
},
"aggregations" : {
"min_fees" : {
"meta" : {
"dsc" : "Lowest Fees This Year"
},
"value" : 2850.0
}
}
}
Estas API son responsables de administrar todos los aspectos del índice, como configuraciones, alias, asignaciones, plantillas de índice.
Crear índice
Esta API le ayuda a crear un índice. Se puede crear un índice automáticamente cuando un usuario pasa objetos JSON a cualquier índice o se puede crear antes de eso. Para crear un índice, solo necesita enviar una solicitud PUT con configuraciones, asignaciones y alias o simplemente una solicitud simple sin cuerpo.
PUT colleges
Al ejecutar el código anterior, obtenemos el resultado como se muestra a continuación:
{
"acknowledged" : true,
"shards_acknowledged" : true,
"index" : "colleges"
}
También podemos agregar algunas configuraciones al comando anterior:
PUT colleges
{
"settings" : {
"index" : {
"number_of_shards" : 3,
"number_of_replicas" : 2
}
}
}
Al ejecutar el código anterior, obtenemos el resultado como se muestra a continuación:
{
"acknowledged" : true,
"shards_acknowledged" : true,
"index" : "colleges"
}
Eliminar índice
Esta API le ayuda a eliminar cualquier índice. Solo necesita pasar una solicitud de eliminación con el nombre de ese índice en particular.
DELETE /colleges
Puede eliminar todos los índices simplemente usando _todos o *.
Obtener índice
Esta API se puede llamar simplemente enviando una solicitud de obtención a uno o más índices. Esto devuelve la información sobre index.
GET colleges
Al ejecutar el código anterior, obtenemos el resultado como se muestra a continuación:
{
"colleges" : {
"aliases" : {
"alias_1" : { },
"alias_2" : {
"filter" : {
"term" : {
"user" : "pkay"
}
},
"index_routing" : "pkay",
"search_routing" : "pkay"
}
},
"mappings" : { },
"settings" : {
"index" : {
"creation_date" : "1556245406616",
"number_of_shards" : "1",
"number_of_replicas" : "1",
"uuid" : "3ExJbdl2R1qDLssIkwDAug",
"version" : {
"created" : "7000099"
},
"provided_name" : "colleges"
}
}
}
}
Puede obtener la información de todos los índices utilizando _todos o *.
El índice existe
La existencia de un índice se puede determinar simplemente enviando una solicitud de obtención a ese índice. Si la respuesta HTTP es 200, existe; si es 404, no existe.
HEAD colleges
Al ejecutar el código anterior, obtenemos el resultado como se muestra a continuación:
200-OK
Configuración de índice
Puede obtener la configuración del índice simplemente agregando la palabra clave _settings al final de la URL.
GET /colleges/_settings
Al ejecutar el código anterior, obtenemos el resultado como se muestra a continuación:
{
"colleges" : {
"settings" : {
"index" : {
"creation_date" : "1556245406616",
"number_of_shards" : "1",
"number_of_replicas" : "1",
"uuid" : "3ExJbdl2R1qDLssIkwDAug",
"version" : {
"created" : "7000099"
},
"provided_name" : "colleges"
}
}
}
}
Estadísticas de índice
Esta API le ayuda a extraer estadísticas sobre un índice en particular. Solo necesita enviar una solicitud de obtención con la URL del índice y la palabra clave _stats al final.
GET /_stats
Al ejecutar el código anterior, obtenemos el resultado como se muestra a continuación:
………………………………………………
},
"request_cache" : {
"memory_size_in_bytes" : 849,
"evictions" : 0,
"hit_count" : 1171,
"miss_count" : 4
},
"recovery" : {
"current_as_source" : 0,
"current_as_target" : 0,
"throttle_time_in_millis" : 0
}
} ………………………………………………
Enjuagar
El proceso de vaciado de un índice asegura que cualquier dato que actualmente solo se conserva en el registro de transacciones también se conserva permanentemente en Lucene. Esto reduce los tiempos de recuperación, ya que no es necesario volver a indexar los datos de los registros de transacciones después de que se abra Lucene indexado.
POST colleges/_flush
Al ejecutar el código anterior, obtenemos el resultado como se muestra a continuación:
{
"_shards" : {
"total" : 2,
"successful" : 1,
"failed" : 0
}
}
Por lo general, los resultados de varias API de Elasticsearch se muestran en formato JSON. Pero JSON no siempre es fácil de leer. Por lo tanto, la función de API de cat está disponible en Elasticsearch y ayuda a proporcionar un formato de impresión de los resultados más fácil de leer y comprender. Hay varios parámetros utilizados en la API de cat que sirven para diferentes propósitos, por ejemplo, el término V hace que la salida sea detallada.
Aprendamos sobre las API de cat con más detalle en este capítulo.
Verboso
La salida detallada ofrece una buena visualización de los resultados de un comando cat. En el ejemplo que se muestra a continuación, obtenemos los detalles de varios índices presentes en el clúster.
GET /_cat/indices?v
Al ejecutar el código anterior, obtenemos la respuesta como se muestra a continuación:
health status index uuid pri rep docs.count docs.deleted store.size pri.store.size
yellow open schools RkMyEn2SQ4yUgzT6EQYuAA 1 1 2 1 21.6kb 21.6kb
yellow open index_4_analysis zVmZdM1sTV61YJYrNXf1gg 1 1 0 0 283b 283b
yellow open sensor-2018-01-01 KIrrHwABRB-ilGqTu3OaVQ 1 1 1 0 4.2kb 4.2kb
yellow open colleges 3ExJbdl2R1qDLssIkwDAug 1 1 0 0 283b 283b
Encabezados
El parámetro h, también llamado encabezado, se usa para mostrar solo las columnas mencionadas en el comando.
GET /_cat/nodes?h=ip,port
Al ejecutar el código anterior, obtenemos la respuesta como se muestra a continuación:
127.0.0.1 9300
Ordenar
El comando sort acepta una cadena de consulta que puede ordenar la tabla por columna especificada en la consulta. El orden predeterminado es ascendente, pero esto se puede cambiar agregando: desc a una columna.
El siguiente ejemplo da un resultado de plantillas dispuestas en orden descendente de los patrones de índice archivados.
GET _cat/templates?v&s=order:desc,index_patterns
Al ejecutar el código anterior, obtenemos la respuesta como se muestra a continuación:
name index_patterns order version
.triggered_watches [.triggered_watches*] 2147483647
.watch-history-9 [.watcher-history-9*] 2147483647
.watches [.watches*] 2147483647
.kibana_task_manager [.kibana_task_manager] 0 7000099
Contar
El parámetro de recuento proporciona el recuento del número total de documentos en todo el clúster.
GET /_cat/count?v
Al ejecutar el código anterior, obtenemos la respuesta como se muestra a continuación:
epoch timestamp count
1557633536 03:58:56 17809
La API del clúster se utiliza para obtener información sobre el clúster y sus nodos y para realizar cambios en ellos. Para llamar a esta API, necesitamos especificar el nombre del nodo, la dirección o _local.
GET /_nodes/_local
Al ejecutar el código anterior, obtenemos la respuesta como se muestra a continuación:
………………………………………………
cluster_name" : "elasticsearch",
"nodes" : {
"FKH-5blYTJmff2rJ_lQOCg" : {
"name" : "ubuntu",
"transport_address" : "127.0.0.1:9300",
"host" : "127.0.0.1",
"ip" : "127.0.0.1",
"version" : "7.0.0",
"build_flavor" : "default",
"build_type" : "tar",
"build_hash" : "b7e28a7",
"total_indexing_buffer" : 106502553,
"roles" : [
"master",
"data",
"ingest"
],
"attributes" : {
………………………………………………
Salud del clúster
Esta API se usa para obtener el estado de la salud del clúster agregando la palabra clave 'salud'.
GET /_cluster/health
Al ejecutar el código anterior, obtenemos la respuesta como se muestra a continuación:
{
"cluster_name" : "elasticsearch",
"status" : "yellow",
"timed_out" : false,
"number_of_nodes" : 1,
"number_of_data_nodes" : 1,
"active_primary_shards" : 7,
"active_shards" : 7,
"relocating_shards" : 0,
"initializing_shards" : 0,
"unassigned_shards" : 4,
"delayed_unassigned_shards" : 0,
"number_of_pending_tasks" : 0,
"number_of_in_flight_fetch" : 0,
"task_max_waiting_in_queue_millis" : 0,
"active_shards_percent_as_number" : 63.63636363636363
}
Estado del clúster
Esta API se utiliza para obtener información sobre el estado de un clúster agregando la URL de la palabra clave "estado". La información de estado contiene versión, nodo maestro, otros nodos, tabla de enrutamiento, metadatos y bloques.
GET /_cluster/state
Al ejecutar el código anterior, obtenemos la respuesta como se muestra a continuación:
………………………………………………
{
"cluster_name" : "elasticsearch",
"cluster_uuid" : "IzKu0OoVTQ6LxqONJnN2eQ",
"version" : 89,
"state_uuid" : "y3BlwvspR1eUQBTo0aBjig",
"master_node" : "FKH-5blYTJmff2rJ_lQOCg",
"blocks" : { },
"nodes" : {
"FKH-5blYTJmff2rJ_lQOCg" : {
"name" : "ubuntu",
"ephemeral_id" : "426kTGpITGixhEzaM-5Qyg",
"transport
}
………………………………………………
Estadísticas de clúster
Esta API ayuda a recuperar estadísticas sobre el clúster mediante el uso de la palabra clave 'stats'. Esta API devuelve el número de fragmentos, el tamaño de la tienda, el uso de memoria, la cantidad de nodos, las funciones, el sistema operativo y el sistema de archivos.
GET /_cluster/stats
Al ejecutar el código anterior, obtenemos la respuesta como se muestra a continuación:
………………………………………….
"cluster_name" : "elasticsearch",
"cluster_uuid" : "IzKu0OoVTQ6LxqONJnN2eQ",
"timestamp" : 1556435464704,
"status" : "yellow",
"indices" : {
"count" : 7,
"shards" : {
"total" : 7,
"primaries" : 7,
"replication" : 0.0,
"index" : {
"shards" : {
"min" : 1,
"max" : 1,
"avg" : 1.0
},
"primaries" : {
"min" : 1,
"max" : 1,
"avg" : 1.0
},
"replication" : {
"min" : 0.0,
"max" : 0.0,
"avg" : 0.0
}
………………………………………….
Configuración de actualización de clúster
Esta API le permite actualizar la configuración de un clúster mediante la palabra clave 'configuración'. Hay dos tipos de configuraciones: persistentes (aplicadas entre reinicios) y transitorias (no sobreviven a un reinicio completo del clúster).
Estadísticas de nodo
Esta API se utiliza para recuperar las estadísticas de uno más nodos del clúster. Las estadísticas de los nodos son casi las mismas que las del clúster.
GET /_nodes/stats
Al ejecutar el código anterior, obtenemos la respuesta como se muestra a continuación:
{
"_nodes" : {
"total" : 1,
"successful" : 1,
"failed" : 0
},
"cluster_name" : "elasticsearch",
"nodes" : {
"FKH-5blYTJmff2rJ_lQOCg" : {
"timestamp" : 1556437348653,
"name" : "ubuntu",
"transport_address" : "127.0.0.1:9300",
"host" : "127.0.0.1",
"ip" : "127.0.0.1:9300",
"roles" : [
"master",
"data",
"ingest"
],
"attributes" : {
"ml.machine_memory" : "4112797696",
"xpack.installed" : "true",
"ml.max_open_jobs" : "20"
},
………………………………………………………….
Nodos hot_threads
Esta API le ayuda a recuperar información sobre los hot threads actuales en cada nodo del clúster.
GET /_nodes/hot_threads
Al ejecutar el código anterior, obtenemos la respuesta como se muestra a continuación:
:::{ubuntu}{FKH-5blYTJmff2rJ_lQOCg}{426kTGpITGixhEzaM5Qyg}{127.0.0.1}{127.0.0.1:9300}{ml.machine_memory=4112797696,
xpack.installed=true, ml.max_open_jobs=20}
Hot threads at 2019-04-28T07:43:58.265Z, interval=500ms, busiestThreads=3,
ignoreIdleThreads=true:
En Elasticsearch, la búsqueda se realiza mediante consultas basadas en JSON. Una consulta se compone de dos cláusulas:
Leaf Query Clauses - Estas cláusulas son coincidencia, término o rango, que buscan un valor específico en un campo específico.
Compound Query Clauses - Estas consultas son una combinación de cláusulas de consulta hoja y otras consultas compuestas para extraer la información deseada.
Elasticsearch admite una gran cantidad de consultas. Una consulta comienza con una palabra clave de consulta y luego tiene condiciones y filtros en su interior en forma de objeto JSON. A continuación se describen los diferentes tipos de consultas.
Coincidir con todas las consultas
Ésta es la consulta más básica; devuelve todo el contenido y con una puntuación de 1,0 para cada objeto.
POST /schools/_search
{
"query":{
"match_all":{}
}
}
Al ejecutar el código anterior, obtenemos el siguiente resultado:
{
"took" : 7,
"timed_out" : false,
"_shards" : {
"total" : 1,
"successful" : 1,
"skipped" : 0,
"failed" : 0
},
"hits" : {
"total" : {
"value" : 2,
"relation" : "eq"
},
"max_score" : 1.0,
"hits" : [
{
"_index" : "schools",
"_type" : "school",
"_id" : "5",
"_score" : 1.0,
"_source" : {
"name" : "Central School",
"description" : "CBSE Affiliation",
"street" : "Nagan",
"city" : "paprola",
"state" : "HP",
"zip" : "176115",
"location" : [
31.8955385,
76.8380405
],
"fees" : 2200,
"tags" : [
"Senior Secondary",
"beautiful campus"
],
"rating" : "3.3"
}
},
{
"_index" : "schools",
"_type" : "school",
"_id" : "4",
"_score" : 1.0,
"_source" : {
"name" : "City Best School",
"description" : "ICSE",
"street" : "West End",
"city" : "Meerut",
"state" : "UP",
"zip" : "250002",
"location" : [
28.9926174,
77.692485
],
"fees" : 3500,
"tags" : [
"fully computerized"
],
"rating" : "4.5"
}
}
]
}
}
Consultas de texto completo
Estas consultas se utilizan para buscar un cuerpo de texto completo, como un capítulo o un artículo de noticias. Esta consulta funciona de acuerdo con el analizador asociado con ese índice o documento en particular. En esta sección, discutiremos los diferentes tipos de consultas de texto completo.
Consulta de coincidencia
Esta consulta hace coincidir un texto o una frase con los valores de uno o más campos.
POST /schools*/_search
{
"query":{
"match" : {
"rating":"4.5"
}
}
}
Al ejecutar el código anterior, obtenemos la respuesta como se muestra a continuación:
{
"took" : 44,
"timed_out" : false,
"_shards" : {
"total" : 1,
"successful" : 1,
"skipped" : 0,
"failed" : 0
},
"hits" : {
"total" : {
"value" : 1,
"relation" : "eq"
},
"max_score" : 0.47000363,
"hits" : [
{
"_index" : "schools",
"_type" : "school",
"_id" : "4",
"_score" : 0.47000363,
"_source" : {
"name" : "City Best School",
"description" : "ICSE",
"street" : "West End",
"city" : "Meerut",
"state" : "UP",
"zip" : "250002",
"location" : [
28.9926174,
77.692485
],
"fees" : 3500,
"tags" : [
"fully computerized"
],
"rating" : "4.5"
}
}
]
}
}
Consulta de coincidencias múltiples
Esta consulta hace coincidir un texto o una frase con más de un campo.
POST /schools*/_search
{
"query":{
"multi_match" : {
"query": "paprola",
"fields": [ "city", "state" ]
}
}
}
Al ejecutar el código anterior, obtenemos la respuesta como se muestra a continuación:
{
"took" : 12,
"timed_out" : false,
"_shards" : {
"total" : 1,
"successful" : 1,
"skipped" : 0,
"failed" : 0
},
"hits" : {
"total" : {
"value" : 1,
"relation" : "eq"
},
"max_score" : 0.9808292,
"hits" : [
{
"_index" : "schools",
"_type" : "school",
"_id" : "5",
"_score" : 0.9808292,
"_source" : {
"name" : "Central School",
"description" : "CBSE Affiliation",
"street" : "Nagan",
"city" : "paprola",
"state" : "HP",
"zip" : "176115",
"location" : [
31.8955385,
76.8380405
],
"fees" : 2200,
"tags" : [
"Senior Secondary",
"beautiful campus"
],
"rating" : "3.3"
}
}
]
}
}
Consulta de cadena de consulta
Esta consulta utiliza un analizador de consultas y la palabra clave query_string.
POST /schools*/_search
{
"query":{
"query_string":{
"query":"beautiful"
}
}
}
Al ejecutar el código anterior, obtenemos la respuesta como se muestra a continuación:
{
"took" : 60,
"timed_out" : false,
"_shards" : {
"total" : 1,
"successful" : 1,
"skipped" : 0,
"failed" : 0
},
"hits" : {
"total" : {
"value" : 1,
"relation" : "eq"
},
………………………………….
Consultas de nivel de término
Estas consultas tratan principalmente con datos estructurados como números, fechas y enumeraciones.
POST /schools*/_search
{
"query":{
"term":{"zip":"176115"}
}
}
Al ejecutar el código anterior, obtenemos la respuesta como se muestra a continuación:
……………………………..
hits" : [
{
"_index" : "schools",
"_type" : "school",
"_id" : "5",
"_score" : 0.9808292,
"_source" : {
"name" : "Central School",
"description" : "CBSE Affiliation",
"street" : "Nagan",
"city" : "paprola",
"state" : "HP",
"zip" : "176115",
"location" : [
31.8955385,
76.8380405
],
}
}
]
…………………………………………..
Consulta de rango
Esta consulta se utiliza para encontrar los objetos que tienen valores entre los rangos de valores dados. Para ello, necesitamos utilizar operadores como:
- gte - mayor que igual a
- gt - mayor que
- lte - menor que igual a
- lt - menos que
Por ejemplo, observe el código que se proporciona a continuación:
POST /schools*/_search
{
"query":{
"range":{
"rating":{
"gte":3.5
}
}
}
}
Al ejecutar el código anterior, obtenemos la respuesta como se muestra a continuación:
{
"took" : 24,
"timed_out" : false,
"_shards" : {
"total" : 1,
"successful" : 1,
"skipped" : 0,
"failed" : 0
},
"hits" : {
"total" : {
"value" : 1,
"relation" : "eq"
},
"max_score" : 1.0,
"hits" : [
{
"_index" : "schools",
"_type" : "school",
"_id" : "4",
"_score" : 1.0,
"_source" : {
"name" : "City Best School",
"description" : "ICSE",
"street" : "West End",
"city" : "Meerut",
"state" : "UP",
"zip" : "250002",
"location" : [
28.9926174,
77.692485
],
"fees" : 3500,
"tags" : [
"fully computerized"
],
"rating" : "4.5"
}
}
]
}
}
También existen otros tipos de consultas de nivel de término como:
Exists query - Si un determinado campo tiene un valor no nulo.
Missing query - Esto es completamente opuesto a la consulta existente, esta consulta busca objetos sin campos específicos o campos que tengan valor nulo.
Wildcard or regexp query - Esta consulta usa expresiones regulares para encontrar patrones en los objetos.
Consultas compuestas
Estas consultas son una colección de consultas diferentes fusionadas entre sí mediante el uso de operadores booleanos como y, o, no o para diferentes índices o con llamadas a funciones, etc.
POST /schools/_search
{
"query": {
"bool" : {
"must" : {
"term" : { "state" : "UP" }
},
"filter": {
"term" : { "fees" : "2200" }
},
"minimum_should_match" : 1,
"boost" : 1.0
}
}
}
Al ejecutar el código anterior, obtenemos la respuesta como se muestra a continuación:
{
"took" : 6,
"timed_out" : false,
"_shards" : {
"total" : 1,
"successful" : 1,
"skipped" : 0,
"failed" : 0
},
"hits" : {
"total" : {
"value" : 0,
"relation" : "eq"
},
"max_score" : null,
"hits" : [ ]
}
}
Consultas geográficas
Estas consultas tratan con ubicaciones geográficas y puntos geográficos. Estas consultas ayudan a encontrar escuelas o cualquier otro objeto geográfico cercano a cualquier ubicación. Debe utilizar el tipo de datos de punto geográfico.
PUT /geo_example
{
"mappings": {
"properties": {
"location": {
"type": "geo_shape"
}
}
}
}
Al ejecutar el código anterior, obtenemos la respuesta como se muestra a continuación:
{ "acknowledged" : true,
"shards_acknowledged" : true,
"index" : "geo_example"
}
Ahora publicamos los datos en el índice creado anteriormente.
POST /geo_example/_doc?refresh
{
"name": "Chapter One, London, UK",
"location": {
"type": "point",
"coordinates": [11.660544, 57.800286]
}
}
Al ejecutar el código anterior, obtenemos la respuesta como se muestra a continuación:
{
"took" : 1,
"timed_out" : false,
"_shards" : {
"total" : 1,
"successful" : 1,
"skipped" : 0,
"failed" : 0
},
"hits" : {
"total" : {
"value" : 2,
"relation" : "eq"
},
"max_score" : 1.0,
"hits" : [
"_index" : "geo_example",
"_type" : "_doc",
"_id" : "hASWZ2oBbkdGzVfiXHKD",
"_score" : 1.0,
"_source" : {
"name" : "Chapter One, London, UK",
"location" : {
"type" : "point",
"coordinates" : [
11.660544,
57.800286
]
}
}
}
}
El mapeo es el esquema de los documentos almacenados en un índice. Define el tipo de datos como geo_point o cadena y formato de los campos presentes en los documentos y reglas para controlar el mapeo de campos agregados dinámicamente.
PUT bankaccountdetails
{
"mappings":{
"properties":{
"name": { "type":"text"}, "date":{ "type":"date"},
"balance":{ "type":"double"}, "liability":{ "type":"double"}
}
}
}
Cuando ejecutamos el código anterior, obtenemos la respuesta como se muestra a continuación:
{
"acknowledged" : true,
"shards_acknowledged" : true,
"index" : "bankaccountdetails"
}
Tipos de datos de campo
Elasticsearch admite varios tipos de datos diferentes para los campos de un documento. Los tipos de datos utilizados para almacenar campos en Elasticsearch se analizan en detalle aquí.
Tipos de datos principales
Estos son los tipos de datos básicos como texto, palabra clave, fecha, largo, doble, booleano o ip, que son compatibles con casi todos los sistemas.
Tipos de datos complejos
Estos tipos de datos son una combinación de tipos de datos básicos. Estos incluyen matriz, objeto JSON y tipo de datos anidados. A continuación se muestra un ejemplo de tipo de datos anidados y menos
POST /tabletennis/_doc/1
{
"group" : "players",
"user" : [
{
"first" : "dave", "last" : "jones"
},
{
"first" : "kevin", "last" : "morris"
}
]
}
Cuando ejecutamos el código anterior, obtenemos la respuesta como se muestra a continuación:
{
"_index" : "tabletennis",
"_type" : "_doc",
"_id" : "1",
_version" : 2,
"result" : "updated",
"_shards" : {
"total" : 2,
"successful" : 1,
"failed" : 0
},
"_seq_no" : 1,
"_primary_term" : 1
}
Otro código de muestra se muestra a continuación:
POST /accountdetails/_doc/1
{
"from_acc":"7056443341", "to_acc":"7032460534",
"date":"11/1/2016", "amount":10000
}
Cuando ejecutamos el código anterior, obtenemos la respuesta como se muestra a continuación:
{ "_index" : "accountdetails",
"_type" : "_doc",
"_id" : "1",
"_version" : 1,
"result" : "created",
"_shards" : {
"total" : 2,
"successful" : 1,
"failed" : 0
},
"_seq_no" : 1,
"_primary_term" : 1
}
Podemos verificar el documento anterior usando el siguiente comando:
GET /accountdetails/_mappings?include_type_name=false
Eliminación de tipos de mapeo
Los índices creados en Elasticsearch 7.0.0 o posterior ya no aceptan una asignación _default_. Los índices creados en 6.x seguirán funcionando como antes en Elasticsearch 6.x. Los tipos están en desuso en las API en 7.0.
Cuando se procesa una consulta durante una operación de búsqueda, el módulo de análisis analiza el contenido de cualquier índice. Este módulo consta de analizador, tokenizador, filtros de token y filtros de caracteres. Si no se define ningún analizador, entonces, de forma predeterminada, los analizadores, token, filtros y tokenizadores integrados se registran con el módulo de análisis.
En el siguiente ejemplo, usamos un analizador estándar que se usa cuando no se especifica ningún otro analizador. Analizará la oración basándose en la gramática y producirá palabras utilizadas en la oración.
POST _analyze
{
"analyzer": "standard",
"text": "Today's weather is beautiful"
}
Al ejecutar el código anterior, obtenemos la respuesta como se muestra a continuación:
{
"tokens" : [
{
"token" : "today's",
"start_offset" : 0,
"end_offset" : 7,
"type" : "",
"position" : 0
},
{
"token" : "weather",
"start_offset" : 8,
"end_offset" : 15,
"type" : "",
"position" : 1
},
{
"token" : "is",
"start_offset" : 16,
"end_offset" : 18,
"type" : "",
"position" : 2
},
{
"token" : "beautiful",
"start_offset" : 19,
"end_offset" : 28,
"type" : "",
"position" : 3
}
]
}
Configuración del analizador estándar
Podemos configurar el analizador estándar con varios parámetros para obtener nuestros requisitos personalizados.
En el siguiente ejemplo, configuramos el analizador estándar para que tenga un max_token_length de 5.
Para esto, primero creamos un índice con el analizador que tiene el parámetro max_length_token.
PUT index_4_analysis
{
"settings": {
"analysis": {
"analyzer": {
"my_english_analyzer": {
"type": "standard",
"max_token_length": 5,
"stopwords": "_english_"
}
}
}
}
}
A continuación, aplicamos el analizador con un texto como se muestra a continuación. Tenga en cuenta que el token no aparece, ya que tiene dos espacios al principio y dos espacios al final. Para la palabra "es", hay un espacio al principio y un espacio al final. Tomando todos ellos, se convierte en 4 letras con espacios y eso no lo convierte en una palabra. Debe haber un carácter sin espacio al menos al principio o al final, para que sea una palabra a contar.
POST index_4_analysis/_analyze
{
"analyzer": "my_english_analyzer",
"text": "Today's weather is beautiful"
}
Al ejecutar el código anterior, obtenemos la respuesta como se muestra a continuación:
{
"tokens" : [
{
"token" : "today",
"start_offset" : 0,
"end_offset" : 5,
"type" : "",
"position" : 0
},
{
"token" : "s",
"start_offset" : 6,
"end_offset" : 7,
"type" : "",
"position" : 1
},
{
"token" : "weath",
"start_offset" : 8,
"end_offset" : 13,
"type" : "",
"position" : 2
},
{
"token" : "er",
"start_offset" : 13,
"end_offset" : 15,
"type" : "",
"position" : 3
},
{
"token" : "beaut",
"start_offset" : 19,
"end_offset" : 24,
"type" : "",
"position" : 5
},
{
"token" : "iful",
"start_offset" : 24,
"end_offset" : 28,
"type" : "",
"position" : 6
}
]
}
La lista de varios analizadores y su descripción se dan en la tabla que se muestra a continuación:
S. No | Analizador y descripción |
---|---|
1 | Standard analyzer (standard) Se pueden configurar palabras irrelevantes y max_token_length para este analizador. De forma predeterminada, la lista de palabras vacías está vacía y max_token_length es 255. |
2 | Simple analyzer (simple) Este analizador está compuesto por un tokenizador en minúsculas. |
3 | Whitespace analyzer (whitespace) Este analizador está compuesto por un tokenizador de espacios en blanco. |
4 | Stop analyzer (stop) Se pueden configurar palabras irrelevantes y palabras irrelevantes_ruta. De forma predeterminada, las palabras vacías se inicializan en palabras vacías en inglés y stopwords_path contiene la ruta a un archivo de texto con palabras vacías. |
Tokenizadores
Los tokens se utilizan para generar tokens a partir de un texto en Elasticsearch. El texto se puede dividir en tokens teniendo en cuenta los espacios en blanco u otros signos de puntuación. Elasticsearch tiene muchos tokenizadores integrados, que se pueden usar en un analizador personalizado.
A continuación se muestra un ejemplo de tokenizador que divide el texto en términos cada vez que encuentra un carácter que no es una letra, pero que también pone todos los términos en minúsculas:
POST _analyze
{
"tokenizer": "lowercase",
"text": "It Was a Beautiful Weather 5 Days ago."
}
Al ejecutar el código anterior, obtenemos la respuesta como se muestra a continuación:
{
"tokens" : [
{
"token" : "it",
"start_offset" : 0,
"end_offset" : 2,
"type" : "word",
"position" : 0
},
{
"token" : "was",
"start_offset" : 3,
"end_offset" : 6,
"type" : "word",
"position" : 1
},
{
"token" : "a",
"start_offset" : 7,
"end_offset" : 8,
"type" : "word",
"position" : 2
},
{
"token" : "beautiful",
"start_offset" : 9,
"end_offset" : 18,
"type" : "word",
"position" : 3
},
{
"token" : "weather",
"start_offset" : 19,
"end_offset" : 26,
"type" : "word",
"position" : 4
},
{
"token" : "days",
"start_offset" : 29,
"end_offset" : 33,
"type" : "word",
"position" : 5
},
{
"token" : "ago",
"start_offset" : 34,
"end_offset" : 37,
"type" : "word",
"position" : 6
}
]
}
Aquí se muestra una lista de Tokenizadores y sus descripciones en la tabla que se muestra a continuación:
S. No | Tokenizer y descripción |
---|---|
1 | Standard tokenizer (standard) Esto se basa en un tokenizador basado en gramática y max_token_length se puede configurar para este tokenizador. |
2 | Edge NGram tokenizer (edgeNGram) Se pueden establecer configuraciones como min_gram, max_gram, token_chars para este tokenizador. |
3 | Keyword tokenizer (keyword) Esto genera la entrada completa como salida y buffer_size se puede configurar para esto. |
4 | Letter tokenizer (letter) Esto captura la palabra completa hasta que se encuentra una que no es una letra. |
Elasticsearch está compuesto por una serie de módulos, que son responsables de su funcionalidad. Estos módulos tienen dos tipos de configuración de la siguiente manera:
Static Settings- Estas configuraciones deben configurarse en el archivo de configuración (elasticsearch.yml) antes de iniciar Elasticsearch. Debe actualizar todos los nodos de preocupación en el clúster para reflejar los cambios de esta configuración.
Dynamic Settings - Estas configuraciones se pueden establecer en Elasticsearch en vivo.
Discutiremos los diferentes módulos de Elasticsearch en las siguientes secciones de este capítulo.
Enrutamiento a nivel de clúster y asignación de fragmentos
La configuración del nivel de clúster decide la asignación de fragmentos a diferentes nodos y la reasignación de fragmentos para reequilibrar el clúster. Estas son las siguientes configuraciones para controlar la asignación de particiones.
Asignación de fragmentos a nivel de clúster
Ajuste | Valor posible | Descripción |
---|---|---|
cluster.routing.allocation.enable | ||
todas | Este valor predeterminado permite la asignación de fragmentos para todo tipo de fragmentos. | |
primarias | Esto permite la asignación de fragmentos solo para fragmentos primarios. | |
new_primaries | Esto permite la asignación de fragmentos solo para fragmentos primarios para nuevos índices. | |
ninguna | Esto no permite asignaciones de fragmentos. | |
cluster.routing.allocation .node_concurrent_recoveries | Valor numérico (por defecto 2) | Esto restringe el número de recuperación de fragmentos simultáneos. |
cluster.routing.allocation .node_initial_primaries_recoveries | Valor numérico (por defecto 4) | Esto restringe el número de recuperaciones primarias iniciales paralelas. |
cluster.routing.allocation .same_shard.host | Valor booleano (por defecto falso) | Esto restringe la asignación de más de una réplica del mismo fragmento en el mismo nodo físico. |
indices.recovery.concurrent _streams | Valor numérico (por defecto 3) | Esto controla la cantidad de flujos de red abiertos por nodo en el momento de la recuperación de fragmentos de fragmentos de pares. |
indices.recovery.concurrent _small_file_streams | Valor numérico (por defecto 2) | Esto controla la cantidad de flujos abiertos por nodo para archivos pequeños que tienen un tamaño inferior a 5 MB en el momento de la recuperación del fragmento. |
cluster.routing.rebalance.enable | ||
todas | Este valor predeterminado permite el equilibrio de todo tipo de fragmentos. | |
primarias | Esto permite el equilibrio de fragmentos solo para fragmentos primarios. | |
réplicas | Esto permite el equilibrio de fragmentos solo para fragmentos de réplica. | |
ninguna | Esto no permite ningún tipo de equilibrio de fragmentos. | |
cluster.routing.allocation .allow_rebalance | ||
siempre | Este valor predeterminado siempre permite reequilibrar. | |
indices_primaries _active | Esto permite el reequilibrio cuando se asignan todos los fragmentos primarios del clúster. | |
Índices_todos_activos | Esto permite reequilibrar cuando se asignan todos los fragmentos primarios y de réplica. | |
cluster.routing.allocation.cluster _concurrent_rebalance | Valor numérico (por defecto 2) | Esto restringe la cantidad de equilibrio de particiones simultáneas en el clúster. |
cluster.routing.allocation .balance.shard | Valor flotante (por defecto 0.45f) | Esto define el factor de peso para los fragmentos asignados en cada nodo. |
cluster.routing.allocation .balance.index | Valor flotante (por defecto 0.55f) | Esto define la proporción de la cantidad de fragmentos por índice asignados en un nodo específico. |
cluster.routing.allocation .balance.threshold | Valor flotante no negativo (por defecto 1.0f) | Este es el valor mínimo de optimización de las operaciones que se deben realizar. |
Asignación de fragmentos basada en disco
Ajuste | Valor posible | Descripción |
---|---|---|
cluster.routing.allocation.disk.threshold_enabled | Valor booleano (por defecto verdadero) | Esto habilita y deshabilita el decisor de asignación de disco. |
cluster.routing.allocation.disk.watermark.low | Valor de cadena (por defecto 85%) | Esto denota el uso máximo de disco; después de este punto, no se puede asignar ningún otro fragmento a ese disco. |
cluster.routing.allocation.disk.watermark.high | Valor de cadena (por defecto 90%) | Esto denota el uso máximo en el momento de la asignación; si se alcanza este punto en el momento de la asignación, Elasticsearch asignará ese fragmento a otro disco. |
cluster.info.update.interval | Valor de cadena (por defecto 30 s) | Este es el intervalo entre las comprobaciones de uso del disco. |
cluster.routing.allocation.disk.include_relocations | Valor booleano (por defecto verdadero) | Esto decide si se deben considerar los fragmentos que se están asignando actualmente, mientras se calcula el uso del disco. |
Descubrimiento
Este módulo ayuda a un clúster a descubrir y mantener el estado de todos los nodos que contiene. El estado del clúster cambia cuando se agrega o se elimina un nodo. La configuración del nombre del clúster se utiliza para crear una diferencia lógica entre diferentes clústeres. Hay algunos módulos que lo ayudan a utilizar las API proporcionadas por los proveedores de la nube y se detallan a continuación:
- Descubrimiento de Azure
- Descubrimiento de EC2
- Descubrimiento del motor de cálculo de Google
- Descubrimiento zen
Puerta
Este módulo mantiene el estado del clúster y los datos de la partición durante los reinicios completos del clúster. Los siguientes son los ajustes estáticos de este módulo:
Ajuste | Valor posible | Descripción |
---|---|---|
gateway.expected_nodes | valor numérico (por defecto 0) | La cantidad de nodos que se espera que estén en el clúster para la recuperación de fragmentos locales. |
gateway.expected_master_nodes | valor numérico (por defecto 0) | La cantidad de nodos maestros que se espera que estén en el clúster antes de iniciar la recuperación. |
gateway.expected_data_nodes | valor numérico (por defecto 0) | La cantidad de nodos de datos esperados en el clúster antes de iniciar la recuperación. |
gateway.recover_after_time | Valor de cadena (por defecto 5 m) | Este es el intervalo entre las comprobaciones de uso del disco. |
cluster.routing.allocation. disk.include_relocations | Valor booleano (por defecto verdadero) | Esto especifica el tiempo que esperará el proceso de recuperación para comenzar, independientemente de la cantidad de nodos unidos en el clúster. gateway.recover_ after_nodes |
HTTP
Este módulo gestiona la comunicación entre el cliente HTTP y las API de Elasticsearch. Este módulo se puede desactivar cambiando el valor de http.enabled a falso.
Las siguientes son las configuraciones (configuradas en elasticsearch.yml) para controlar este módulo:
S. No | Configuración y descripción |
---|---|
1 | http.port Este es un puerto para acceder a Elasticsearch y oscila entre 9200-9300. |
2 | http.publish_port Este puerto es para clientes http y también es útil en caso de firewall. |
3 | http.bind_host Esta es una dirección de host para el servicio http. |
4 | http.publish_host Esta es una dirección de host para el cliente http. |
5 | http.max_content_length Este es el tamaño máximo de contenido en una solicitud http. Su valor predeterminado es 100 MB. |
6 | http.max_initial_line_length Este es el tamaño máximo de URL y su valor predeterminado es 4kb. |
7 | http.max_header_size Este es el tamaño máximo de encabezado http y su valor predeterminado es 8 kb. |
8 | http.compression Esto habilita o deshabilita la compatibilidad con la compresión y su valor predeterminado es falso. |
9 | http.pipelinig Esto habilita o deshabilita la canalización HTTP. |
10 | http.pipelining.max_events Esto restringe el número de eventos que se pondrán en cola antes de cerrar una solicitud HTTP. |
Índices
Este módulo mantiene la configuración, que se establece globalmente para cada índice. Las siguientes configuraciones están relacionadas principalmente con el uso de la memoria:
Cortacircuitos
Esto se usa para evitar que la operación cause un OutOfMemroyError. La configuración restringe principalmente el tamaño del montón de JVM. Por ejemplo, la configuración indices.breaker.total.limit, que por defecto es el 70% del montón de JVM.
Caché de datos de campo
Esto se usa principalmente al agregar en un campo. Se recomienda tener suficiente memoria para asignarlo. La cantidad de memoria utilizada para la caché de datos de campo se puede controlar mediante la configuración de indices.fielddata.cache.size.
Caché de consultas de nodo
Esta memoria se utiliza para almacenar en caché los resultados de la consulta. Esta caché utiliza la política de desalojo de menos usados recientemente (LRU). La configuración de Indices.queries.cahce.size controla el tamaño de la memoria de esta caché.
Búfer de indexación
Este búfer almacena los documentos recién creados en el índice y los vacía cuando el búfer está lleno. La configuración como indices.memory.index_buffer_size controla la cantidad de montón asignada para este búfer.
Caché de solicitud de fragmentos
Esta caché se usa para almacenar los datos de búsqueda local para cada fragmento. La caché se puede habilitar durante la creación del índice o se puede deshabilitar enviando un parámetro de URL.
Disable cache - ?request_cache = true
Enable cache "index.requests.cache.enable": true
Recuperación de índices
Controla los recursos durante el proceso de recuperación. Las siguientes son las configuraciones:
Ajuste | Valor por defecto |
---|---|
indices.recovery.concurrent_streams | 3 |
indices.recovery.concurrent_small_file_streams | 2 |
indices.recovery.file_chunk_size | 512 KB |
indices.recovery.translog_ops | 1000 |
indices.recovery.translog_size | 512 KB |
indices.recovery.compress | cierto |
indices.recovery.max_bytes_per_sec | 40 MB |
Intervalo TTL
El intervalo de tiempo de vida (TTL) define el tiempo de un documento, después del cual se elimina el documento. Las siguientes son las configuraciones dinámicas para controlar este proceso:
Ajuste | Valor por defecto |
---|---|
indices.ttl.interval | Años 60 |
indices.ttl.bulk_size | 1000 |
Nodo
Cada nodo tiene la opción de ser nodo de datos o no. Puede cambiar esta propiedad cambiandonode.dataajuste. Establecer el valor comofalse define que el nodo no es un nodo de datos.
Estos son los módulos que se crean para cada índice y controlan la configuración y el comportamiento de los índices. Por ejemplo, cuántos fragmentos puede usar un índice o el número de réplicas que puede tener un fragmento principal para ese índice, etc. Hay dos tipos de configuraciones de índice:
- Static - Estos se pueden configurar solo en el momento de la creación del índice o en un índice cerrado.
- Dynamic - Estos se pueden cambiar en un índice en vivo.
Configuración de índice estático
La siguiente tabla muestra la lista de configuraciones de índices estáticos:
Ajuste | Valor posible | Descripción |
---|---|---|
index.number_of_shards | El valor predeterminado es 5, máximo 1024 | El número de fragmentos primarios que debe tener un índice. |
index.shard.check_on_startup | El valor predeterminado es falso. Puede ser verdad | Si los fragmentos deben verificarse o no por daños antes de abrirlos. |
index.codec | Compresión LZ4. | Tipo de compresión utilizada para almacenar datos. |
index.routing_partition_size | 1 | La cantidad de fragmentos a los que puede ir un valor de enrutamiento personalizado. |
index.load_fixed_bitset_filters_eagerly | falso | Indica si los filtros almacenados en caché están precargados para consultas anidadas |
Configuración de índice dinámico
La siguiente tabla muestra la lista de configuraciones de índices dinámicos:
Ajuste | Valor posible | Descripción |
---|---|---|
index.number_of_replicas | Predeterminado a 1 | La cantidad de réplicas que tiene cada fragmento principal. |
index.auto_expand_replicas | Un guión delimitado límite inferior y superior (0-5) | Expanda automáticamente la cantidad de réplicas según la cantidad de nodos de datos en el clúster. |
index.search.idle.after | 30 segundos | Cuánto tiempo un fragmento no puede recibir una búsqueda u obtener una solicitud hasta que se considera que la búsqueda está inactiva. |
index.refresh_interval | 1 segundo | Con qué frecuencia se realiza una operación de actualización, que hace que los cambios recientes en el índice sean visibles para la búsqueda. |
index.blocks.read_only | 1 verdadero / falso | Establézcalo en verdadero para hacer que el índice y los metadatos del índice sean de solo lectura, falso para permitir escrituras y cambios de metadatos. |
A veces necesitamos transformar un documento antes de indexarlo. Por ejemplo, queremos eliminar un campo del documento o cambiar el nombre de un campo y luego indexarlo. Esto es manejado por el nodo Ingest.
Cada nodo del clúster tiene la capacidad de ingesta, pero también se puede personalizar para que sea procesado solo por nodos específicos.
Pasos involucrados
Hay dos pasos involucrados en el funcionamiento del nodo de ingesta:
- Creando una tubería
- Creando un documento
Crear una canalización
Primero creando una canalización que contiene los procesadores y luego ejecutando la canalización, como se muestra a continuación:
PUT _ingest/pipeline/int-converter
{
"description": "converts the content of the seq field to an integer",
"processors" : [
{
"convert" : {
"field" : "seq",
"type": "integer"
}
}
]
}
Al ejecutar el código anterior, obtenemos el siguiente resultado:
{
"acknowledged" : true
}
Crear un documento
A continuación, creamos un documento utilizando el convertidor de canalización.
PUT /logs/_doc/1?pipeline=int-converter
{
"seq":"21",
"name":"Tutorialspoint",
"Addrs":"Hyderabad"
}
Al ejecutar el código anterior, obtenemos la respuesta como se muestra a continuación:
{
"_index" : "logs",
"_type" : "_doc",
"_id" : "1",
"_version" : 1,
"result" : "created",
"_shards" : {
"total" : 2,
"successful" : 1,
"failed" : 0
},
"_seq_no" : 0,
"_primary_term" : 1
}
A continuación, buscamos el documento creado anteriormente usando el comando GET como se muestra a continuación:
GET /logs/_doc/1
Al ejecutar el código anterior, obtenemos el siguiente resultado:
{
"_index" : "logs",
"_type" : "_doc",
"_id" : "1",
"_version" : 1,
"_seq_no" : 0,
"_primary_term" : 1,
"found" : true,
"_source" : {
"Addrs" : "Hyderabad",
"name" : "Tutorialspoint",
"seq" : 21
}
}
Puede ver arriba que 21 se ha convertido en un número entero.
Sin Pipeline
Ahora creamos un documento sin usar la canalización.
PUT /logs/_doc/2
{
"seq":"11",
"name":"Tutorix",
"Addrs":"Secunderabad"
}
GET /logs/_doc/2
Al ejecutar el código anterior, obtenemos el siguiente resultado:
{
"_index" : "logs",
"_type" : "_doc",
"_id" : "2",
"_version" : 1,
"_seq_no" : 1,
"_primary_term" : 1,
"found" : true,
"_source" : {
"seq" : "11",
"name" : "Tutorix",
"Addrs" : "Secunderabad"
}
}
Puede ver arriba que 11 es una cadena sin que se utilice la canalización.
La gestión del ciclo de vida del índice implica realizar acciones de gestión basadas en factores como el tamaño del fragmento y los requisitos de rendimiento. Las API de administración del ciclo de vida del índice (ILM) le permiten automatizar cómo desea administrar sus índices a lo largo del tiempo.
Este capítulo ofrece una lista de API de ILM y su uso.
API de administración de políticas
Nombre de API | Propósito | Ejemplo |
---|---|---|
Cree una política de ciclo de vida. | Crea una política de ciclo de vida. Si existe la política especificada, la política se reemplaza y la versión de la política se incrementa. | PUT_ilm / policy / policy_id |
Obtenga la política del ciclo de vida. | Devuelve la definición de política especificada. Incluye la versión de la póliza y la fecha de la última modificación. Si no se especifica ninguna política, devuelve todas las políticas definidas. | GET_ilm / policy / policy_id |
Eliminar política de ciclo de vida | Elimina la definición de política de ciclo de vida especificada. No puede eliminar las políticas que están actualmente en uso. Si la política se utiliza para administrar índices, la solicitud falla y devuelve un error. | DELETE_ilm / policy / policy_id |
API de gestión de índices
Nombre de API | Propósito | Ejemplo |
---|---|---|
Pasar a la API del paso del ciclo de vida. | Mueve manualmente un índice al paso especificado y ejecuta ese paso. | POST_ilm / move / index |
Política de reintento. | Vuelve a establecer la política en el paso donde ocurrió el error y ejecuta el paso. | POST index / _ilm / reintentar |
Eliminar la política de la edición de la API de índice. | Elimina la política de ciclo de vida asignada y deja de administrar el índice especificado. Si se especifica un patrón de índice, elimina las políticas asignadas de todos los índices coincidentes. | POST index / _ilm / remove |
API de gestión de operaciones
Nombre de API | Propósito | Ejemplo |
---|---|---|
Obtenga la API de estado de administración del ciclo de vida del índice. | Devuelve el estado del complemento ILM. El campo operation_mode en la respuesta muestra uno de tres estados: INICIADO, DETENIDO o DETENIDO. | GET / _ilm / status |
Inicie la API de gestión del ciclo de vida del índice. | Inicia el complemento ILM si está detenido actualmente. ILM se inicia automáticamente cuando se forma el clúster. | POST / _ilm / inicio |
Detenga la API de administración del ciclo de vida del índice. | Detiene todas las operaciones de gestión del ciclo de vida y detiene el complemento ILM. Esto es útil cuando está realizando mantenimiento en el clúster y necesita evitar que ILM realice acciones en sus índices. | POST / _ilm / detener |
Explica la API del ciclo de vida. | Recupera información sobre el estado actual del ciclo de vida del índice, como la fase, la acción y el paso en ejecución. Muestra cuándo ingresó el índice en cada uno, la definición de la fase de ejecución e información sobre las fallas. | OBTENER índice / _ilm / explicar |
Es un componente que permite ejecutar consultas similares a SQL en tiempo real contra Elasticsearch. Puede pensar en Elasticsearch SQL como un traductor, uno que comprende tanto SQL como Elasticsearch y facilita la lectura y el procesamiento de datos en tiempo real, a escala, aprovechando las capacidades de Elasticsearch.
Ventajas de Elasticsearch SQL
It has native integration - Todas y cada una de las consultas se ejecutan de manera eficiente contra los nodos relevantes de acuerdo con el almacenamiento subyacente.
No external parts - No se necesita hardware, procesos, tiempos de ejecución o bibliotecas adicionales para consultar Elasticsearch.
Lightweight and efficient - Adopta y expone SQL para permitir una búsqueda de texto completo adecuada, en tiempo real.
Ejemplo
PUT /schoollist/_bulk?refresh
{"index":{"_id": "CBSE"}}
{"name": "GleanDale", "Address": "JR. Court Lane", "start_date": "2011-06-02",
"student_count": 561}
{"index":{"_id": "ICSE"}}
{"name": "Top-Notch", "Address": "Gachibowli Main Road", "start_date": "1989-
05-26", "student_count": 482}
{"index":{"_id": "State Board"}}
{"name": "Sunshine", "Address": "Main Street", "start_date": "1965-06-01",
"student_count": 604}
Al ejecutar el código anterior, obtenemos la respuesta como se muestra a continuación:
{
"took" : 277,
"errors" : false,
"items" : [
{
"index" : {
"_index" : "schoollist",
"_type" : "_doc",
"_id" : "CBSE",
"_version" : 1,
"result" : "created",
"forced_refresh" : true,
"_shards" : {
"total" : 2,
"successful" : 1,
"failed" : 0
},
"_seq_no" : 0,
"_primary_term" : 1,
"status" : 201
}
},
{
"index" : {
"_index" : "schoollist",
"_type" : "_doc",
"_id" : "ICSE",
"_version" : 1,
"result" : "created",
"forced_refresh" : true,
"_shards" : {
"total" : 2,
"successful" : 1,
"failed" : 0
},
"_seq_no" : 1,
"_primary_term" : 1,
"status" : 201
}
},
{
"index" : {
"_index" : "schoollist",
"_type" : "_doc",
"_id" : "State Board",
"_version" : 1,
"result" : "created",
"forced_refresh" : true,
"_shards" : {
"total" : 2,
"successful" : 1,
"failed" : 0
},
"_seq_no" : 2,
"_primary_term" : 1,
"status" : 201
}
}
]
}
Consulta SQL
El siguiente ejemplo muestra cómo enmarcamos la consulta SQL:
POST /_sql?format=txt
{
"query": "SELECT * FROM schoollist WHERE start_date < '2000-01-01'"
}
Al ejecutar el código anterior, obtenemos la respuesta como se muestra a continuación:
Address | name | start_date | student_count
--------------------+---------------+------------------------+---------------
Gachibowli Main Road|Top-Notch |1989-05-26T00:00:00.000Z|482
Main Street |Sunshine |1965-06-01T00:00:00.000Z|604
Note - Al cambiar la consulta SQL anterior, puede obtener diferentes conjuntos de resultados.
Para monitorear el estado del clúster, la función de monitoreo recopila métricas de cada nodo y las almacena en Elasticsearch Indices. Todas las configuraciones asociadas con la supervisión en Elasticsearch deben establecerse en el archivo elasticsearch.yml para cada nodo o, cuando sea posible, en la configuración del clúster dinámico.
Para comenzar a monitorear, debemos verificar la configuración del clúster, lo que se puede hacer de la siguiente manera:
GET _cluster/settings
{
"persistent" : { },
"transient" : { }
}
Cada componente de la pila es responsable de monitorearse a sí mismo y luego reenviar esos documentos al clúster de producción de Elasticsearch para enrutamiento e indexación (almacenamiento). Los procesos de enrutamiento e indexación en Elasticsearch son manejados por lo que se llaman recolectores y exportadores.
Coleccionistas
El recopilador se ejecuta una vez por cada intervalo de recopilación para obtener datos de las API públicas en Elasticsearch que elige monitorear. Una vez finalizada la recopilación de datos, los datos se entregan a granel a los exportadores para ser enviados al grupo de monitoreo.
Solo hay un recopilador por tipo de datos recopilados. Cada recolector puede crear cero o más documentos de monitoreo.
Exportadores
Los exportadores toman los datos recopilados de cualquier fuente de Elastic Stack y los enrutan al clúster de monitoreo. Es posible configurar más de un exportador, pero la configuración general y predeterminada es utilizar un solo exportador. Los exportadores se pueden configurar tanto a nivel de nodo como de clúster.
Hay dos tipos de exportadores en Elasticsearch:
local - Este exportador enruta los datos al mismo clúster.
http - El exportador preferido, que puede utilizar para enrutar datos a cualquier clúster de Elasticsearch compatible accesible a través de HTTP.
Antes de que los exportadores puedan enrutar los datos de monitoreo, deben configurar ciertos recursos de Elasticsearch. Estos recursos incluyen plantillas y canalizaciones de ingesta
Un trabajo de resumen es una tarea periódica que resume los datos de los índices especificados por un patrón de índice y los convierte en un nuevo índice. En el siguiente ejemplo, creamos un índice llamado sensor con diferentes marcas de fecha y hora. Luego, creamos un trabajo de resumen para acumular los datos de estos índices periódicamente usando el trabajo cron.
PUT /sensor/_doc/1
{
"timestamp": 1516729294000,
"temperature": 200,
"voltage": 5.2,
"node": "a"
}
Al ejecutar el código anterior, obtenemos el siguiente resultado:
{
"_index" : "sensor",
"_type" : "_doc",
"_id" : "1",
"_version" : 1,
"result" : "created",
"_shards" : {
"total" : 2,
"successful" : 1,
"failed" : 0
},
"_seq_no" : 0,
"_primary_term" : 1
}
Ahora, agregue un segundo documento y así sucesivamente para otros documentos también.
PUT /sensor-2018-01-01/_doc/2
{
"timestamp": 1413729294000,
"temperature": 201,
"voltage": 5.9,
"node": "a"
}
Crear un trabajo de resumen
PUT _rollup/job/sensor
{
"index_pattern": "sensor-*",
"rollup_index": "sensor_rollup",
"cron": "*/30 * * * * ?",
"page_size" :1000,
"groups" : {
"date_histogram": {
"field": "timestamp",
"interval": "60m"
},
"terms": {
"fields": ["node"]
}
},
"metrics": [
{
"field": "temperature",
"metrics": ["min", "max", "sum"]
},
{
"field": "voltage",
"metrics": ["avg"]
}
]
}
El parámetro cron controla cuándo y con qué frecuencia se activa el trabajo. Cuando se activa la programación cron de un trabajo de acumulación, comenzará a acumularse desde donde lo dejó después de la última activación
Una vez que el trabajo se ha ejecutado y procesado algunos datos, podemos usar la consulta DSL para hacer algunas búsquedas.
GET /sensor_rollup/_rollup_search
{
"size": 0,
"aggregations": {
"max_temperature": {
"max": {
"field": "temperature"
}
}
}
}
Los índices que se buscan con frecuencia se guardan en la memoria porque se necesita tiempo para reconstruirlos y ayudar en una búsqueda eficiente. Por otro lado, puede haber índices a los que rara vez accedemos. Esos índices no necesitan ocupar la memoria y se pueden reconstruir cuando se necesiten. Estos índices se conocen como índices congelados.
Elasticsearch crea las estructuras de datos transitorias de cada fragmento de un índice congelado cada vez que se busca ese fragmento y descarta estas estructuras de datos tan pronto como se completa la búsqueda. Debido a que Elasticsearch no mantiene estas estructuras de datos transitorias en la memoria, los índices congelados consumen mucho menos montón que los índices normales. Esto permite una proporción de disco a montón mucho más alta de lo que sería posible de otro modo.
Ejemplo de congelación y descongelación
El siguiente ejemplo congela y descongela un índice:
POST /index_name/_freeze
POST /index_name/_unfreeze
Se espera que las búsquedas de índices congelados se ejecuten lentamente. Los índices congelados no están pensados para una carga de búsqueda alta. Es posible que una búsqueda de un índice congelado tarde segundos o minutos en completarse, incluso si las mismas búsquedas se completaron en milisegundos cuando los índices no estaban congelados.
Búsqueda de un índice congelado
El número de índices congelados cargados simultáneamente por nodo está limitado por el número de subprocesos en el grupo de subprocesos search_throttled, que es 1 de forma predeterminada. Para incluir índices congelados, se debe ejecutar una solicitud de búsqueda con el parámetro de consulta: ignore_throttled = false.
GET /index_name/_search?q=user:tpoint&ignore_throttled=false
Supervisión de índices congelados
Los índices congelados son índices ordinarios que utilizan la limitación de búsqueda y una implementación de fragmentos de memoria eficiente.
GET /_cat/indices/index_name?v&h=i,sth
Elasticsearch proporciona un archivo jar, que se puede agregar a cualquier IDE de Java y se puede utilizar para probar el código relacionado con Elasticsearch. Se pueden realizar diversas pruebas utilizando el marco proporcionado por Elasticsearch. En este capítulo, discutiremos estas pruebas en detalle:
- Examen de la unidad
- Pruebas de integración
- Pruebas aleatorias
Prerrequisitos
Para comenzar con las pruebas, debe agregar la dependencia de pruebas de Elasticsearch a su programa. Puede usar maven para este propósito y puede agregar lo siguiente en pom.xml.
<dependency>
<groupId>org.elasticsearch</groupId>
<artifactId>elasticsearch</artifactId>
<version>2.1.0</version>
</dependency>
EsSetup se ha inicializado para iniciar y detener el nodo Elasticsearch y también para crear índices.
EsSetup esSetup = new EsSetup();
La función esSetup.execute () con createIndex creará los índices, debe especificar la configuración, el tipo y los datos.
Examen de la unidad
La prueba unitaria se lleva a cabo utilizando JUnit y el marco de prueba Elasticsearch. El nodo y los índices se pueden crear usando clases de Elasticsearch y en el método de prueba se pueden usar para realizar las pruebas. Las clases ESTestCase y ESTokenStreamTestCase se utilizan para esta prueba.
Pruebas de integración
Las pruebas de integración utilizan varios nodos en un clúster. La clase ESIntegTestCase se utiliza para esta prueba. Hay varios métodos que facilitan el trabajo de preparar un caso de prueba.
S. No | Método y descripción |
---|---|
1 | refresh() Todos los índices de un clúster se actualizan |
2 | ensureGreen() Garantiza un estado de clúster de salud verde |
3 | ensureYellow() Garantiza un estado de clúster de salud amarillo |
4 | createIndex(name) Crea un índice con el nombre pasado a este método |
5 | flush() Todos los índices del clúster se vacían |
6 | flushAndRefresh() flush () y actualizar () |
7 | indexExists(name) Verifica la existencia de un índice especificado |
8 | clusterService() Devuelve la clase java del servicio de clúster. |
9 | cluster() Devuelve la clase de clúster de prueba |
Métodos de grupos de prueba
S. No | Método y descripción |
---|---|
1 | ensureAtLeastNumNodes(n) Garantiza que el número mínimo de nodos en un clúster sea mayor o igual al número especificado. |
2 | ensureAtMostNumNodes(n) Garantiza que el número máximo de nodos en un clúster sea menor o igual al número especificado. |
3 | stopRandomNode() Para detener un nodo aleatorio en un clúster |
4 | stopCurrentMasterNode() Para detener el nodo maestro |
5 | stopRandomNonMaster() Para detener un nodo aleatorio en un clúster, que no es un nodo principal. |
6 | buildNode() Crea un nuevo nodo |
7 | startNode(settings) Iniciar un nuevo nodo |
8 | nodeSettings() Anule este método para cambiar la configuración del nodo. |
Acceder a clientes
Se utiliza un cliente para acceder a diferentes nodos de un clúster y realizar alguna acción. El método ESIntegTestCase.client () se utiliza para obtener un cliente aleatorio. Elasticsearch ofrece otros métodos también para acceder al cliente y se puede acceder a esos métodos utilizando el método ESIntegTestCase.internalCluster ().
S. No | Método y descripción |
---|---|
1 | iterator() Esto le ayuda a acceder a todos los clientes disponibles. |
2 | masterClient() Esto devuelve un cliente, que se está comunicando con el nodo maestro. |
3 | nonMasterClient() Esto devuelve un cliente que no se comunica con el nodo maestro. |
4 | clientNodeClient() Esto devuelve un cliente actualmente en el nodo del cliente. |
Pruebas aleatorias
Esta prueba se utiliza para probar el código del usuario con todos los datos posibles, de modo que no haya fallas en el futuro con ningún tipo de datos. Los datos aleatorios son la mejor opción para realizar esta prueba.
Generando datos aleatorios
En esta prueba, la instancia proporcionada por RandomizedTest crea una instancia de la clase Random y ofrece muchos métodos para obtener diferentes tipos de datos.
Método | Valor devuelto |
---|---|
getRandom () | Instancia de clase aleatoria |
randomBoolean () | Booleano aleatorio |
randomByte () | Byte aleatorio |
randomShort () | Corto aleatorio |
randomInt () | Entero aleatorio |
randomLong () | Largo aleatorio |
randomFloat () | Flotador aleatorio |
randomDouble () | Doble aleatorio |
randomLocale () | Configuración regional aleatoria |
randomTimeZone () | Zona horaria aleatoria |
randomFrom () | Elemento aleatorio de la matriz |
Afirmaciones
Las clases ElasticsearchAssertions y ElasticsearchGeoAssertions contienen aserciones, que se utilizan para realizar algunas comprobaciones comunes en el momento de la prueba. Por ejemplo, observe el código dado aquí:
SearchResponse seearchResponse = client().prepareSearch();
assertHitCount(searchResponse, 6);
assertFirstHit(searchResponse, hasId("6"));
assertSearchHits(searchResponse, "1", "2", "3", "4",”5”,”6”);
Un panel de Kibana es una colección de visualizaciones y búsquedas. Puede organizar, cambiar el tamaño y editar el contenido del panel y luego guardar el panel para poder compartirlo. En este capítulo, veremos cómo crear y editar un tablero.
Creación de tablero
Desde la página de inicio de Kibana, seleccione la opción de panel de control de las barras de control de la izquierda como se muestra a continuación. Esto le pedirá que cree un nuevo panel.
Para agregar visualizaciones al tablero, elegimos el menú Agregar y seleccionamos entre las visualizaciones prediseñadas disponibles. Elegimos las siguientes opciones de visualización de la lista.
Al seleccionar las visualizaciones anteriores, obtenemos el tablero como se muestra aquí. Luego podemos agregar y editar el tablero para cambiar los elementos y agregar los nuevos elementos.
Inspección de elementos
Podemos inspeccionar los elementos del Tablero eligiendo el menú del panel de visualizaciones y seleccionando Inspect. Esto mostrará los datos detrás del elemento que también se pueden descargar.
Panel de control compartido
Podemos compartir el tablero eligiendo el menú Compartir y seleccionando la opción para obtener un hipervínculo como se muestra a continuación:
La funcionalidad de descubrimiento disponible en la página de inicio de Kibana nos permite explorar los conjuntos de datos desde varios ángulos. Puede buscar y filtrar datos para los patrones de índice seleccionados. Los datos suelen estar disponibles en forma de distribución de valores durante un período de tiempo.
Para explorar la muestra de datos de comercio electrónico, hacemos clic en el Discovericono como se muestra en la siguiente imagen. Esto hará que aparezcan los datos junto con el gráfico.
Filtrar por tiempo
Para filtrar los datos por intervalo de tiempo específico, usamos la opción de filtro de tiempo como se muestra a continuación. De forma predeterminada, el filtro está configurado en 15 minutos.
Filtrar por campos
El conjunto de datos también se puede filtrar por campos utilizando el Add Filteropción como se muestra a continuación. Aquí agregamos uno o más campos y obtenemos el resultado correspondiente después de aplicar los filtros. En nuestro ejemplo elegimos el campoday_of_week y luego el operador de ese campo como is y valora como Sunday.
A continuación, hacemos clic en Guardar con las condiciones de filtro anteriores. El conjunto de resultados que contiene las condiciones de filtro aplicadas se muestra a continuación.
La tabla de datos es un tipo de visualización que se utiliza para mostrar los datos sin procesar de una agregación compuesta. Hay varios tipos de agregaciones que se presentan mediante tablas de datos. Para crear una tabla de datos, debemos seguir los pasos que se describen aquí en detalle.
Visualizar
En la pantalla de inicio de Kibana encontramos la opción de nombre Visualizar que nos permite crear visualizaciones y agregaciones a partir de los índices almacenados en Elasticsearch. La siguiente imagen muestra la opción.
Seleccionar tabla de datos
A continuación, seleccionamos la opción Tabla de datos entre las diversas opciones de visualización disponibles. La opción se muestra en la siguiente imagen & miuns;
Seleccionar métricas
Luego, seleccionamos las métricas necesarias para crear la visualización de la tabla de datos. Esta elección decide el tipo de agregación que vamos a utilizar. Seleccionamos los campos específicos que se muestran a continuación del conjunto de datos de comercio electrónico para esto.
Al ejecutar la configuración anterior para la tabla de datos, obtenemos el resultado como se muestra en la imagen aquí:
Los mapas de región muestran métricas en un mapa geográfico. Es útil para mirar los datos anclados a diferentes regiones geográficas con intensidad variable. Los tonos más oscuros suelen indicar valores más altos y los tonos más claros indican valores más bajos.
Los pasos para crear esta visualización se explican en detalle a continuación:
Visualizar
En este paso vamos al botón de visualizar disponible en la barra izquierda de la pantalla de inicio de Kibana y luego elegimos la opción para agregar una nueva Visualización.
La siguiente pantalla muestra cómo elegimos la opción Mapa de región.
Elija las métricas
La siguiente pantalla nos pide que elijamos las métricas que se utilizarán para crear el mapa de la región. Aquí elegimos el precio promedio como métrica y country_iso_code como el campo en el segmento que se utilizará para crear la visualización.
El resultado final a continuación muestra el mapa de la región una vez que aplicamos la selección. Tenga en cuenta las tonalidades del color y sus valores mencionados en la etiqueta.
Los gráficos circulares son una de las herramientas de visualización más simples y famosas. Representa los datos como sectores de un círculo, cada uno de los cuales tiene un color diferente. Las etiquetas junto con los valores de los datos porcentuales se pueden presentar junto con el círculo. El círculo también puede tomar la forma de una rosquilla.
Visualizar
En la pantalla de inicio de Kibana, encontramos la opción de nombre Visualizar que nos permite crear visualización y agregaciones a partir de los índices almacenados en Elasticsearch. Elegimos agregar una nueva visualización y seleccionar un gráfico circular como la opción que se muestra a continuación.
Elija las métricas
La siguiente pantalla nos pide que elijamos las métricas que se utilizarán para crear el gráfico circular. Aquí elegimos el recuento del precio unitario base como métrica y la agregación de cubos como histograma. Además, el intervalo mínimo se elige como 20. Por lo tanto, los precios se mostrarán como bloques de valores con 20 como rango.
El resultado a continuación muestra el gráfico circular después de aplicar la selección. Tenga en cuenta las tonalidades del color y sus valores mencionados en la etiqueta.
Opciones de gráfico circular
Al pasar a la pestaña de opciones debajo del gráfico circular, podemos ver varias opciones de configuración para cambiar el aspecto, así como la disposición de la visualización de datos en el gráfico circular. En el siguiente ejemplo, el gráfico circular aparece como una dona y las etiquetas aparecen en la parte superior.
Un gráfico de áreas es una extensión del gráfico de líneas donde el área entre el gráfico de líneas y los ejes se resalta con algunos colores. Un gráfico de barras representa datos organizados en un rango de valores y luego trazados contra los ejes. Puede constar de barras horizontales o verticales.
En este capítulo veremos los tres tipos de gráficos que se crean usando Kibana. Como se discutió en capítulos anteriores, continuaremos usando los datos en el índice de comercio electrónico.
Gráfico de área
En la pantalla de inicio de Kibana, encontramos la opción de nombre Visualizar que nos permite crear visualización y agregaciones a partir de los índices almacenados en Elasticsearch. Elegimos agregar una nueva visualización y seleccionar Gráfico de área como la opción que se muestra en la imagen que se muestra a continuación.
Elija las métricas
La siguiente pantalla nos pide que elijamos las métricas que se utilizarán en la creación del gráfico de área. Aquí elegimos la suma como el tipo de métrica de agregación. Luego elegimos el campo total_quantity como el campo que se utilizará como métrica. En el eje X, elegimos el campo order_date y dividimos la serie con la métrica dada en un tamaño de 5.
Al ejecutar la configuración anterior, obtenemos el siguiente gráfico de áreas como resultado:
Gráfico de barras horizontales
Del mismo modo, para el gráfico de barras horizontales, elegimos una nueva visualización de la pantalla de inicio de Kibana y elegimos la opción de Barra horizontal. Luego elegimos las métricas como se muestra en la imagen a continuación. Aquí elegimos Suma como la agregación de la cantidad de producto con nombre archivado. Luego elegimos cubos con histograma de fecha para la fecha del pedido de campo.
Al ejecutar la configuración anterior, podemos ver un gráfico de barras horizontales como se muestra a continuación:
Gráfico de barras verticales
Para el gráfico de barras verticales, elegimos una nueva visualización de la pantalla de inicio de Kibana y elegimos la opción de Barra vertical. Luego elegimos las métricas como se muestra en la imagen a continuación.
Aquí elegimos Suma como la agregación para el campo denominado cantidad de producto. Luego, elegimos depósitos con histograma de fecha para la fecha de orden de campo con un intervalo semanal.
Al ejecutar la configuración anterior, se generará un gráfico como se muestra a continuación:
La serie de tiempo es una representación de la secuencia de datos en una secuencia de tiempo específica. Por ejemplo, los datos de cada día desde el primer día del mes hasta el último día. El intervalo entre los puntos de datos permanece constante. Cualquier conjunto de datos que tenga un componente de tiempo puede representarse como una serie de tiempo.
En este capítulo, utilizaremos el conjunto de datos de comercio electrónico de muestra y trazaremos el recuento del número de pedidos de cada día para crear una serie de tiempo.
Elija métricas
Primero, elegimos el patrón de índice, el campo de datos y el intervalo que se usará para crear la serie de tiempo. Del conjunto de datos de comercio electrónico de muestra, elegimos order_date como campo y 1d como intervalo. Usamos elPanel Optionspestaña para hacer estas elecciones. También dejamos los otros valores en esta pestaña como predeterminados para obtener un color y formato predeterminados para la serie temporal.
En el Data pestaña, elegimos contar como la opción de agregación, agrupar por opción como todo y poner una etiqueta para el gráfico de series de tiempo.
Resultado
El resultado final de esta configuración aparece como sigue. Tenga en cuenta que estamos utilizando un período de tiempo deMonth to Datepara este gráfico. Diferentes períodos de tiempo darán resultados diferentes.
Una nube de etiquetas representa texto que son en su mayoría palabras clave y metadatos en una forma visualmente atractiva. Están alineados en diferentes ángulos y representados en diferentes colores y tamaños de fuente. Ayuda a descubrir los términos más destacados en los datos. La prominencia puede decidirse por uno o más factores como la frecuencia del término, la unicidad de la etiqueta o basándose en algún peso adjunto a términos específicos, etc. A continuación, vemos los pasos para crear una nube de etiquetas.
Visualizar
En la pantalla de inicio de Kibana, encontramos la opción de nombre Visualizar que nos permite crear visualización y agregaciones a partir de los índices almacenados en Elasticsearch. Elegimos agregar una nueva visualización y seleccionar Tag Cloud como la opción que se muestra a continuación:
Elija las métricas
La siguiente pantalla nos pide que elijamos las métricas que se utilizarán para crear la nube de etiquetas. Aquí elegimos el recuento como el tipo de métrica de agregación. Luego elegimos el campo productname como la palabra clave que se utilizará como etiquetas.
El resultado que se muestra aquí muestra el gráfico circular después de aplicar la selección. Tenga en cuenta las tonalidades del color y sus valores mencionados en la etiqueta.
Opciones de nube de etiquetas
Al mudarse al optionsEn la pestaña Tag Cloud podemos ver varias opciones de configuración para cambiar el aspecto, así como la disposición de la visualización de datos en Tag Cloud. En el siguiente ejemplo, la nube de etiquetas aparece con etiquetas distribuidas en direcciones horizontales y verticales.
El mapa de calor es un tipo de visualización en el que diferentes tonos de color representan diferentes áreas en el gráfico. Los valores pueden variar continuamente y, por tanto, los matices de color r de un color varían junto con los valores. Son muy útiles para representar tanto los datos que varían continuamente como los datos discretos.
En este capítulo usaremos el conjunto de datos llamado sample_data_flights para construir un gráfico de mapa de calor. En él consideramos las variables denominadas país de origen y país de destino de los vuelos y contamos.
En la pantalla de inicio de Kibana, encontramos la opción de nombre Visualizar que nos permite crear visualización y agregaciones a partir de los índices almacenados en Elasticsearch. Elegimos agregar una nueva visualización y seleccionar Mapa de calor como la opción que se muestra a continuación & mimus;
Elija las métricas
La siguiente pantalla nos pide que elijamos las métricas que se utilizarán en la creación del gráfico de mapa de calor. Aquí elegimos el recuento como el tipo de métrica de agregación. Luego, para los depósitos en el eje Y, elegimos Términos como la agregación para el campo País de origen. Para el eje X, elegimos la misma agregación pero DestCountry como el campo que se utilizará. En ambos casos, elegimos el tamaño del cubo como 5.
Al ejecutar la configuración mostrada anteriormente, obtenemos el gráfico de mapa de calor generado de la siguiente manera.
Note - Debe permitir el rango de fechas como Este año para que el gráfico recopile datos de un año para producir un gráfico de mapa de calor efectivo.
La aplicación Canvas es una parte de Kibana que nos permite crear visualizaciones de datos dinámicas, de múltiples páginas y con píxeles perfectos. Su capacidad para crear infografías y no solo gráficos y métricas es lo que la hace única y atractiva. En este capítulo, veremos varias características del lienzo y cómo usar las almohadillas de trabajo del lienzo.
Abrir un lienzo
Vaya a la página de inicio de Kibana y seleccione la opción como se muestra en el siguiente diagrama. Abre la lista de almohadillas de trabajo de lienzo que tiene. Elegimos el seguimiento de ingresos de comercio electrónico para nuestro estudio.
Clonación de un panel de trabajo
Clonamos el [eCommerce] Revenue Trackingpanel de trabajo que se utilizará en nuestro estudio. Para clonarlo, resaltamos la fila con el nombre de este panel de trabajo y luego usamos el botón de clonar como se muestra en el diagrama a continuación -
Como resultado del clon anterior, obtendremos una nueva plataforma de trabajo llamada [eCommerce] Revenue Tracking – Copy que en la apertura mostrará la siguiente infografía.
Describe las ventas totales y los ingresos por categoría junto con bonitas imágenes y gráficos.
Modificar el área de trabajo
Podemos cambiar el estilo y las figuras en el panel de trabajo usando las opciones disponibles en la pestaña del lado derecho. Aquí nuestro objetivo es cambiar el color de fondo del panel de trabajo eligiendo un color diferente como se muestra en el diagrama a continuación. La selección de color entra en vigor inmediatamente y obtenemos el resultado como se muestra a continuación:
Kibana también puede ayudar a visualizar datos de registro de varias fuentes. Los registros son fuentes importantes de análisis para el estado de la infraestructura, las necesidades de rendimiento y el análisis de violaciones de seguridad, etc. Kibana puede conectarse a varios registros, como registros de servidores web, registros de búsqueda elástica y registros de observación en la nube, etc.
Registros de Logstash
En Kibana, podemos conectarnos a los registros de logstash para visualizarlos. Primero elegimos el botón Registros de la pantalla de inicio de Kibana como se muestra a continuación:
Luego elegimos la opción Change Source Configuration que nos trae la opción de elegir Logstash como fuente. La siguiente pantalla también muestra otros tipos de opciones que tenemos como fuente de registro.
Puede transmitir datos para el seguimiento de registros en vivo o pausar la transmisión para centrarse en los datos de registros históricos. Cuando está transmitiendo registros, el registro más reciente aparece en la parte inferior de la consola.
Para obtener más información, puede consultar nuestro tutorial de Logstash .