mirror of
https://github.com/ClickHouse/ClickHouse.git
synced 2024-11-14 11:33:46 +00:00
98 lines
8.5 KiB
Markdown
98 lines
8.5 KiB
Markdown
---
|
|
machine_translated: false
|
|
machine_translated_rev:
|
|
toc_priority: 0
|
|
toc_title: "Descripción"
|
|
---
|
|
|
|
# ¿Qué es ClickHouse? {#what-is-clickhouse}
|
|
|
|
ClickHouse es un sistema de gestión de bases de datos (DBMS), orientado a columnas, para el procesamiento analítico de consultas en línea (OLAP).
|
|
|
|
En un DBMS “normal”, orientado a filas, los datos se almacenan en este orden:
|
|
|
|
| Fila | Argumento | JavaEnable | Titular | GoodEvent | EventTime |
|
|
|------|-------------|------------|---------------------------|-----------|---------------------|
|
|
| #0 | 89354350662 | 1 | Relaciones con inversores | 1 | 2016-05-18 05:19:20 |
|
|
| #1 | 90329509958 | 0 | Contáctenos | 1 | 2016-05-18 08:10:20 |
|
|
| #2 | 89953706054 | 1 | Mision | 1 | 2016-05-18 07:38:00 |
|
|
| #N | … | … | … | … | … |
|
|
|
|
En otras palabras, todos los valores relacionados con una fila se almacenan físicamente uno junto al otro.
|
|
|
|
Ejemplos de un DBMS orientado a filas son MySQL, Postgres y MS SQL Server.
|
|
|
|
En un DBMS orientado a columnas, los datos se almacenan así:
|
|
|
|
| Fila: | #0 | #1 | #2 | #N |
|
|
|-------------|---------------------------|---------------------|---------------------|-----|
|
|
| Argumento: | 89354350662 | 90329509958 | 89953706054 | … |
|
|
| JavaEnable: | 1 | 0 | 1 | … |
|
|
| Titular: | Relaciones con inversores | Contáctenos | Mision | … |
|
|
| GoodEvent: | 1 | 1 | 1 | … |
|
|
| EventTime: | 2016-05-18 05:19:20 | 2016-05-18 08:10:20 | 2016-05-18 07:38:00 | … |
|
|
|
|
Estos ejemplos solo muestran el orden en el que se organizan los datos. Los valores de diferentes columnas se almacenan por separado y los datos de la misma columna se almacenan juntos.
|
|
|
|
Ejemplos de un DBMS orientado a columnas: Vertica, Paraccel (Actian Matrix y Amazon Redshift), Sybase IQ, Exasol, Infobright, InfiniDB, MonetDB (VectorWise y Actian Vector), LucidDB, SAP HANA, Google Dremel, Google PowerDrill, Druid y kdb+.
|
|
|
|
Los diferentes modos de ordenar los datos al guardarlos se adecúan mejor a diferentes escenarios. El escenario de acceso a los datos se refiere a qué consultas se hacen, con qué frecuencia y en qué proporción; cuántos datos se leen para cada tipo de consulta - filas, columnas y bytes; la relación entre lectura y actualización de datos; el tamaño de trabajo de los datos y qué tan localmente son usados; si se usan transacciones y qué tan aisladas están;requerimientos de replicación de los datos y de integridad lógica, requerimientos de latencia y caudal (throughput) para cada tipo de consulta, y cosas por el estilo.
|
|
|
|
Cuanto mayor sea la carga en el sistema, más importante es personalizar el sistema configurado para que coincida con los requisitos del escenario de uso, y más fino será esta personalización. No existe un sistema que sea igualmente adecuado para escenarios significativamente diferentes. Si un sistema es adaptable a un amplio conjunto de escenarios, bajo una carga alta, el sistema manejará todos los escenarios igualmente mal, o funcionará bien para solo uno o algunos de los escenarios posibles.
|
|
|
|
## Propiedades clave del escenario OLAP {#key-properties-of-olap-scenario}
|
|
|
|
- La gran mayoría de las solicitudes son para acceso de lectura.
|
|
- Los datos se actualizan en lotes bastante grandes (\> 1000 filas), no por filas individuales; o no se actualiza en absoluto.
|
|
- Los datos se agregan a la base de datos pero no se modifican.
|
|
- Para las lecturas, se extrae un número bastante grande de filas de la base de datos, pero solo un pequeño subconjunto de columnas.
|
|
- Las tablas son “wide,” lo que significa que contienen un gran número de columnas.
|
|
- Las consultas son relativamente raras (generalmente cientos de consultas por servidor o menos por segundo).
|
|
- Para consultas simples, se permiten latencias de alrededor de 50 ms.
|
|
- Los valores de columna son bastante pequeños: números y cadenas cortas (por ejemplo, 60 bytes por URL).
|
|
- Requiere un alto rendimiento al procesar una sola consulta (hasta miles de millones de filas por segundo por servidor).
|
|
- Las transacciones no son necesarias.
|
|
- Bajos requisitos para la coherencia de los datos.
|
|
- Hay una tabla grande por consulta. Todas las mesas son pequeñas, excepto una.
|
|
- Un resultado de consulta es significativamente menor que los datos de origen. En otras palabras, los datos se filtran o se agregan, por lo que el resultado se ajusta a la RAM de un solo servidor.
|
|
|
|
Es fácil ver que el escenario OLAP es muy diferente de otros escenarios populares (como el acceso OLTP o Key-Value). Por lo tanto, no tiene sentido intentar usar OLTP o una base de datos de valor clave para procesar consultas analíticas si desea obtener un rendimiento decente. Por ejemplo, si intenta usar MongoDB o Redis para análisis, obtendrá un rendimiento muy bajo en comparación con las bases de datos OLAP.
|
|
|
|
## Por qué las bases de datos orientadas a columnas funcionan mejor en el escenario OLAP {#why-column-oriented-databases-work-better-in-the-olap-scenario}
|
|
|
|
Las bases de datos orientadas a columnas son más adecuadas para los escenarios OLAP: son al menos 100 veces más rápidas en el procesamiento de la mayoría de las consultas. Las razones se explican en detalle a continuación, pero el hecho es más fácil de demostrar visualmente:
|
|
|
|
**DBMS orientado a filas**
|
|
|
|
![Row-oriented](images/row-oriented.gif#)
|
|
|
|
**DBMS orientado a columnas**
|
|
|
|
![Column-oriented](images/column-oriented.gif#)
|
|
|
|
Ver la diferencia?
|
|
|
|
### Entrada/salida {#inputoutput}
|
|
|
|
1. Para una consulta analítica, solo es necesario leer un pequeño número de columnas de tabla. En una base de datos orientada a columnas, puede leer solo los datos que necesita. Por ejemplo, si necesita 5 columnas de 100, puede esperar una reducción de 20 veces en E/S.
|
|
2. Dado que los datos se leen en paquetes, es más fácil de comprimir. Los datos en columnas también son más fáciles de comprimir. Esto reduce aún más el volumen de E/S.
|
|
3. Debido a la reducción de E / S, más datos se ajustan a la memoria caché del sistema.
|
|
|
|
Por ejemplo, la consulta “count the number of records for each advertising platform” requiere leer uno “advertising platform ID” columna, que ocupa 1 byte sin comprimir. Si la mayor parte del tráfico no proviene de plataformas publicitarias, puede esperar al menos una compresión de 10 veces de esta columna. Cuando se utiliza un algoritmo de compresión rápida, la descompresión de datos es posible a una velocidad de al menos varios gigabytes de datos sin comprimir por segundo. En otras palabras, esta consulta se puede procesar a una velocidad de aproximadamente varios miles de millones de filas por segundo en un único servidor. Esta velocidad se logra realmente en la práctica.
|
|
|
|
### CPU {#cpu}
|
|
|
|
Dado que la ejecución de una consulta requiere procesar un gran número de filas, ayuda enviar todas las operaciones para vectores completos en lugar de para filas separadas, o implementar el motor de consultas para que casi no haya costo de envío. Si no hace esto, con cualquier subsistema de disco medio decente, el intérprete de consultas inevitablemente detiene la CPU. Tiene sentido almacenar datos en columnas y procesarlos, cuando sea posible, por columnas.
|
|
|
|
Hay dos formas de hacer esto:
|
|
|
|
1. Un vector motor. Todas las operaciones se escriben para vectores, en lugar de para valores separados. Esto significa que no necesita llamar a las operaciones con mucha frecuencia, y los costos de envío son insignificantes. El código de operación contiene un ciclo interno optimizado.
|
|
|
|
2. Generación de código. El código generado para la consulta tiene todas las llamadas indirectas.
|
|
|
|
Esto no se hace en “normal” bases de datos, porque no tiene sentido cuando se ejecutan consultas simples. Sin embargo, hay excepciones. Por ejemplo, MemSQL utiliza la generación de código para reducir la latencia al procesar consultas SQL. (A modo de comparación, los DBMS analíticos requieren la optimización del rendimiento, no la latencia.)
|
|
|
|
Tenga en cuenta que para la eficiencia de la CPU, el lenguaje de consulta debe ser declarativo (SQL o MDX), o al menos un vector (J, K). La consulta solo debe contener bucles implícitos, lo que permite la optimización.
|
|
|
|
{## [Artículo Original](https://clickhouse.tech/docs/en/) ##}
|