您好!欢迎来到源码码网

列式存储数据库ClickHouse介绍

  • 建站技巧
  • 来源:源码码网
  • 编辑:源码码网
  • 时间:2023-08-19 12:05
  • 阅读:283

一、clickhouse简介

ClickHouse 是俄罗斯的 Yandex 于 2016 年开源的用于在线分析处理查询(OLAP :Online Analytical Processing)MPP架构列式存储数据库(DBMS:Database Management System),能够使用 SQL 查询实时生成分析数据报告。ClickHouse的全称是Click Stream,Data WareHouse。

clickhouse可以做用户行为分析,流批一体

线性扩展和可靠性保障能够原生支持 shard + replication

clickhouse没有走hadoop生态,采用 Local attached storage 作为存储

二、clickhouse特点

1、列式存储:

行式存储的好处:

想查找某个人所有的属性时,可以通过一次磁盘查找加顺序读取就可以;但是当想查所有人的年龄时,需要不停的查找,或者全表扫描才行,遍历的很多数据都是不需要的。

列式存储的好处

1)、对于列的聚合、计数、求和等统计操作优于行式存储

2)、由于某一列的数据类型都是相同的,针对于数据存储更容易进行数据压缩,每一列选择更优的数据压缩算法,大大提高了数据的压缩比重

3)、数据压缩比更好,一方面节省了磁盘空间,另一方面对于cache也有了更大的发挥空间

4)、列式存储不支持事务

2、DBMS功能:几乎覆盖了标准 SQL 的大部分语法,包括 DDL 和 DML、,以及配套的各种函数;用户管理及权限管理、数据的备份与恢复

3、多样化引擎:目前包括合并树、日志、接口和其他四大类20多种引擎。

4、高吞吐写入能力:

ClickHouse采用类LSM Tree的结构,数据写入后定期在后台Compaction。通过类 LSM tree的结构, ClickHouse在数据导入时全部是顺序append写,写入后数据段不可更改,在后台compaction时也是多个段merge sort后顺序写回磁盘。顺序写的特性,充分利用了磁盘的吞吐能力。

5、数据分区与线程及并行:

ClickHouse将数据划分为多个partition,每个partition再进一步划分为多个index granularity(索引粒度),然后通过多个CPU核心分别处理其中的一部分来实现并行数据处理。在这种设计下, 单条 Query 就能利用整机所有 CPU。 极致的并行处理能力,极大的降低了查询延时。

所以, ClickHouse 即使对于大量数据的查询也能够化整为零平行处理。但是有一个弊端就是对于单条查询使用多cpu,就不利于同时并发多条查询。所以对于高 qps 的查询业务并不是强项。

6、ClickHouse 像很多 OLAP 数据库一样,单表查询速度优于关联查询,而且 ClickHouse的两者差距更为明显。

关联查询:clickhouse会将右表加载到内存。

三、clickhouse为什么快?

1、C++可以利用硬件优势

2、摒弃了hadoop生态

3、数据底层以列式存储

4、利用单节点的多核并行处理

5、为数据建立索引一级、二级、稀疏索引

6、使用大量的算法处理数据

7、支持向量化处理

8、预先设计运算模型-预先计算

分布式处理数据

四、引擎作用:

表引擎是 ClickHouse 的一大特色。可以说, 表引擎决定了如何存储表的数据。包括:

1、数据的存储方式和位置

2、支持哪些查询以及如何支持

3、并发数据访问

4、索引的使用

5、是否可以执行多线性请求

6、数据复制参数

五、ClickHouse引擎:

引擎决定了数据的存储位置、存储结构、表的特征(是否修改操作DDL、DDL、是否支持并发操作)

1、数据库引擎:数据库引擎 | ClickHouse文档

目前支持的数据库引擎有5种:

  • 1)、Ordinary:默认引擎,在绝大多数情况下我们都会使用默认引擎,使用时无须刻意声明。在此数据库下可以使用任意类型的表引擎。

  • 2)、Dictionary:字典引擎,此类数据库会自动为所有数据字典创建它们的数据表

  • 3)、Memory:内存引擎,用于存放临时数据。此类数据库下的数据表只会停留在内存中,不会涉及任何磁盘操作,当服务重启后数据会被清除

  • 4)、Lazy:日志引擎,此类数据库下只能使用Log系列的表引擎

  • 5)、MySQL:MySQL引擎,将远程的MySQL服务器中的表映射到ClickHouse中,常用语数据的合并。

  • 6)、MaterializeMySQL:MySQL数据同步;将MySQL数据全量或增量方式同步到clickhouse中,解决mysql服务并发访问压力过大的问题

2、表引擎:表引擎 | ClickHouse文档

image.png


特别声明:
1、如无特殊说明,内容均为本站原创发布,转载请注明出处;
2、部分转载文章已注明出处,转载目的为学习和交流,如有侵犯,请联系客服删除;
3、编辑非《源码码网》的文章均由用户编辑发布,不代表本站立场,如涉及侵犯,请联系删除;
全部评论(0)
推荐阅读
  • CSS中实现元素居中的几种方法
  • CSS中实现元素居中的几种方法
  • 一、元素分类在CSS中,元素大致可以分为以下几种:1.块级元素(Block-levelElements):这些元素以块的形式显示在页面上,每个块级元素会独占一行(除非通过其他CSS属性进行修改)。块级元素可以设置宽度、高度、内边距和外边距。一些常见的块级元素包括,,-,,,
  • 建站技巧
  • 来源:源码码网
  • 编辑:源码码网
  • 时间:2023-12-05 20:28
  • 阅读:115
  • 基于MIT开源协议的后端管理框架Niucloud Admin
  • 基于MIT开源协议的后端管理框架Niucloud Admin
  • 关于NiucloudAdminNiucloudAdmin是一款可以让开发者快速开发通用管理后台的开发框架,前端采用最新的Vite/TypeScript/Vue3/ElementPlus等最新的技术架构,后台结合PHP8、JavaSDK、Python等主流后端语言搭建,框架内置集成了用户权限、代码生成器、表单设计、云存储、短信发送、素材中心、微信及公众号、Api模块一系列开箱就能用的常见业务功能,是一款优秀
  • 源码教程
  • 来源:Niucloud
  • 编辑:源码码网
  • 时间:2023-11-30 21:24
  • 阅读:128
  • 推荐一款网站速度的插件:堡塔网站加速
  • 推荐一款网站速度的插件:堡塔网站加速
  • 我们平常浏览网页的时候,或多或少会遇到网站响应缓慢、加载页面时间长等情况。当前在这个快节奏的互联网时代里,对于用户来说,如果网站响应速度缓慢,大多数用户都不会花长时间去等待网站的加载,从而直接影响了用户的体验感。如果对于一些商业型的网站来说,网站访问加载速度也会影响网站搜索排名和客户的转化。影响网站访问速度的原因有很多,例如服务器的带宽是一个重要指标,我们今天聊的是,在同等带宽配置下,提升网站访问速度的方式,比如使用堡塔网站加速插件。一
  • 行业资讯
  • 来源:公众号:宝塔面板
  • 编辑:源码码网
  • 时间:2023-11-29 11:27
  • 阅读:65
  • gechiui 格尺后台开发框架介绍
  • gechiui 格尺后台开发框架介绍
  • 资源名称:gechiui格尺后台开发框架软件版本:v6.3.5资源分类:企业协同、OA、CMS、企业建站,博客授权方式:开源界面语言:简体中文文件大小:23M更新时间:2023-11-25资源类型:国产软件平台环境:php+mysqlGeChiIUI(格尺后台开发框架),是一款面向中小企业开源的团队协同办公系统框架。GeChiIUI主要功能文章、文件文档管理,表单管理,审批流,知识库。拖拽操作简单方便。并可搭建企业建站、帮助中心、电商
  • 行业资讯
  • 来源:源码码网
  • 编辑:源码码网
  • 时间:2023-11-28 14:48
  • 阅读:51
  • 网站的收录量多于网站索引量是什么原因?
  • 网站的收录量多于网站索引量是什么原因?
  • 大多数情况下,都是网站索引量多余网站收录量,但是也有不少情况是索引量少于收录量的,我的这个网站现在就是这种表现,索引数据1000左右,收录快到3000了,这个有可能是数据的不准确造成的,也有可能就是索引的页面放出情况良好,对应了多个快照页面,造成收录高于索引,要注意的是这两个数据应该相差不会太多,相差太大的话一般都是网站出现了问题,有人可能会说我的网站索引量和收录量完全一致,是不是就不存在问题,其实,收录数据(Site命令)是实时变动
  • 建站技巧
  • 来源:源码码网
  • 编辑:源码码网
  • 时间:2023-11-14 12:34
  • 阅读:703
联系客服
源码代售 源码咨询 素材咨询 联系客服
029-84538663
手机版

扫一扫进手机版
返回顶部