【ClickHouse 特点&安装启动命令 01】

概念:

ClickHouse是开源的列式存储数据库(DBMS),使用C++语言编写,主要用于在线分析处理查询(OLAP),能够使用SQL查询实时生成分析数据报告

OLAP这样的适合做一些一次插入多次查询这样的操作(适合查询),对于新增更新删除就不太擅长了,所以ClickHouse是一种分析性数据库

HBase也是列式存储数据库

mysql、oracle关系型数据库,适合做CROD这样的增删改查的操作  -->行式存储。

一、Clickhouse特点:

1、列式存储

如何理解:举例:需要存储下面的数据

 1)采用行式存储时,数据在磁盘上的组织结构为:

 2)采用列式存储时,数据在磁盘上的组织结构为:

 查询:select xx属性 from 表,例如:查所有人的id属性,列式存储就只需吧id这一列拿出来就可以了,而行式存储就需要不停的查找或者全表扫描才能找到所有人的id,而遍历的很多数据其实是不需要的

新增、更新、删除:insert (id,name,age)from 表,新增和更新时,行式就可以直接把一行的数据插入或者更新即可,而列式只能先插入id,在插入name,最后插入age

所以像ClickHouse、Hbase这样的列式存储数据库,适合一次插入多次查询,而新增、更新、删除就不太适合了,相反像mysql、oracle这样的关系型数据库即行式存储,新增、更新、删除就更加的适合,而查询就相对不太适合

3)列式存储的好处:

  • 对于列的聚合,计数,求和等统计操作优于行式存储
  • 由于某一列的数据类型都是相同的,针对于数据存储更容易进行数据压缩,每一列选择更优的数据压缩算法,大大提高了数据的压缩比重
  • 由于数据压缩比更好,一方面节省了磁盘空间,另一方面对于cache也有了更大的发挥空间

2、DBMS的功能

几乎覆盖了标准SQL的大部分语法,包括DDL(建表语句)、DML(增删改查)以及配套的各种函数,用户管理及权限管理,数据的备份与恢复。

3、多样化引擎

ClichHouse和MySQL类似,把表级的额存储引擎插件化,根据表的不同需求可以设定不同的存储引擎。目前包括合并树(常用->Merge  Tree)、日志、接口、其他 四种大类20多种引擎。

表存储引擎:如mysql的存储引擎innodb(提供事务-->默认、且常用)、mariadb(不提供事务)

4、高吞吐写入能力

ClickHouse采用类LSM Tree的结构,数据写入后定期在后台Compaction(合并)。-->插入相同的数据时会通过version 号控制,只有在合并的时候采取进行去重。通过类LSM Tree的结构,ClickHouse在数据导入时全部是顺序append(追加)写,写入后的数据段不可更改,在后台Compaction时也是多个段merge sort后顺序写回磁盘。顺序写的特点,充分利用了磁盘的吞吐能力,即便在HDD上也有着优异的写入性能

  官方公开benchmark测试显示能够达到50MB-200MB/s的写入吞吐能力,按照每行100byte估算,大约相当于50w-200w/s的写入速度。

5、数据分区和线程级并行

ClickHouse将数据划分为多个partition(分区),每个partition在进一步划分为多个index granularity(索引粒度),然后通过多个cpu核心分别处理 其中的一部分来实现并行数据处理。在这种设计下,单条Query(查询)就能利用整机所有CPU。--->单条查询就会调用所有cpu那么多条查询占用cpu就很多, 所以ClickHouse一个 瓶颈就是很吃CPU,不利于同时并发多条查询

所以对于高QPS的查询业务ClickHouse并不是强项。

  • QPS: query per second 每秒查询次数
  • TPS:Transaction per second 每秒处理事务次数

由此:ClickHouse不适合存储初始数据,而适合处理过的包含大量字段的大宽表

ClickHouse像很多OLAP数据库一样,单表查询速度优于关联查询 -->所以在架构设计时尽量避免join这样的关联存储数据

二、ClickHouse安装

 1、准备工作

1.1、确定防火墙处于关闭状态

//查看防火墙状态 -->running或者not running
firewall-cmd --state

//启动防火墙
systemctl start firewalld

//停止防火墙
systemctl stop firewalld

//重启防火墙
systemctl restart firewalld

-- 查看系统limit限制

-a:显示目前资源限制的设定;
-c <core文件上限>:设定core文件的最大值,单位为区块;
-d <数据节区大小>:程序数据节区的最大值,单位为KB;
-f <文件大小>:shell所能建立的最大文件,单位为区块;
-H:设定资源的硬性限制,也就是管理员所设下的限制;
-m <内存大小>:指定可使用内存的上限,单位为KB;
-n <文件数目>:指定同一时间最多可开启的文件数;
-p <缓冲区大小>:指定管道缓冲区的大小,单位512字节;
-s <堆叠大小>:指定堆叠的上限,单位为KB;
-S:设定资源的弹性限制;
-t <CPU时间>:指定CPU使用时间的上限,单位为秒;
-u <程序数目>:用户最多可开启的程序数目;
-v <虚拟内存大小>:指定可使用的虚拟内存上限,单位为KB。

参考博客:https://www.cnblogs.com/shishibuwan/p/17197906.html

1.2、centos取消打开文件数限制和最大进程数

1)在hadoop100的 /etc/security/limits.conf文件的末尾加入内容

[root@localhost ~]# sudo vi /etc/security/limits.conf
* soft nofile 65536
* hard nofile 65536
* soft nproc 131072
* hard nproc 131072

/*
解释:
第一列:表示用户和用户主,*是所有用户所有组,如果想单独给用户用户组给权限:  test@cytest -->test是用户  cytest是用户组,之间用@隔开即可
第二列:soft 软限制(当前生效),hard 硬限制(最大的上限),所以doft<=hard
第三列::nofile 文件数,nproc 进程数

一般都可以像上面一样,配置成一样的
*/

 2)在hadoop100的/etc/security/limits.d/20-nproc.conf文件的末尾加入以下内容  -->系统的原因只需要limits.conf可以会被覆盖,所以也需要修改此文件 -->20-nproc.conf这个文件如果没有就新建

[root@localhost ~]# sudo vi /etc/security/limits.d/20-nproc.conf
* soft nofile 65536
* hard nofile 65536
* soft nproc 131072
* hard nproc 131072

修改后重启就可以生效 -->  查看是否生效:ulimit -a  看修改的数字是否变了

1.3 安装依赖

1)输入以下2条命令安装

sudo yum install -y libtool

 sudo yum install -y *unixODBC*

注意:在hadhoop101、hadoop102上同样需要执行

1.4 Centos取消SELINUX

1) 修改/etc/selinux/config 中的 SELINUX=disabled

[root@hadoop102 ~]$ sudo vim /etc/selinux/config
SELINUX=disabled

注意:别改错了,然后101、1022两台机器也需要修改,重启三台机器

2、安装启动-->链接clickhouse

  • 启动:sudo systemctl start clickhouse-server
  • 重启:sudo systemctl restart clickhouse-server
  • 查看状态:systemctl status clickhouse-server
  • 使用client链接server:clickhouse-client --host localhost --user default --port 9000 --password 123456
//修改密码

//1、修改users.xml配置文件
sudo vi /etc/clickhouse-server/users.xml
//2、找到 <default> 用户部分,然后设置新的明文密码。例如,如果你想将密码设置为 new_password,则修改为:

<default>
    <password>123456</password>
</default>

//3、删除/etc/clickhouse-server/users.d路径下的default-password.xml  -->只有删除了才能识别新改的密码123456
//4、关闭防火墙
systemctl stop firewalld
//5、重启clickhouse
sudo systemctl restart clickhouse-server
//6、查看clickhouse是否启动
systemctl status clickhouse-server
//7、链接
clickhouse-client --host localhost --user default --port 9000 --password 123456

 

posted @ 2024-09-30 16:21  尘封~~  阅读(83)  评论(0编辑  收藏  举报