1.
绝大多数请求都是用于读访问的2.
数据须要以大批次(大于1000行)进行更新,而不是单行更新;或者根本没有更新操做3.
数据只是添加到数据库,没有必要修改4.
读取数据时,会从数据库中提取出大量的行,但只用到一小部分列5.
表很“宽”,即表中包含大量的列6.
查询频率相对较低(一般每台服务器每秒查询数百次或更少)7.
对于简单查询,容许大约50毫秒的延迟8.
列的值是比较小的数值和短字符串(例如,每一个URL只有60个字节)9.
在处理单个查询时须要高吞吐量(每台服务器每秒高达数十亿行)10.
不须要事务11.
数据一致性要求较低12.
每次查询中只会查询一个大表。除了一个大表,其他都是小表13.
查询结果显著小于数据源。即数据有过滤或聚合。返回结果不超过单个服务器内存大小相应地,使用ClickHouse也有其自己的限制:git
1.
不支持真正的删除/更新支持 不支持事务(期待后续版本支持)2.
不支持二级索引3.
有限的SQL支持,join实现不同凡响4.
不支持窗口功能5.
元数据管理须要人工干预维护
本文不介绍ClickHouse的具体功能,只是讨论监控。牛逼的Altinity公司提供了,clickhouse zabbix监控的脚本及模板,可是导入模板时,发现是3.4版本的,里面有些参数不支持,因此从新制做了3.0版本的模板。github
废话很少说,直接说监控过程。shell
一、前提条件数据库
xmllint已经安装
.clickhouse-client已经安装
./etc/zabbix/zabbix_agentd.conf
. 添加内容: UserParameter=ch_params[*],sh /PATH/TO/zbx_clickhouse_monitor.sh "$1" "HOST_WHERE_CH_IS_RUNNING"
二、说明缓存
/PATH/TO/zbx_clickhouse_monitor.sh
取决于你存放的位置HOST_WHERE_CH_IS_RUNNING
是个可选参数,若是没有指定,localhost是默认使用的。三、导入模板服务器
导入模板:zbx_clickhouse_template.xml
spa
四、数据展现3d
五、图表展现code
附上源码和模板:xml
https://github.com/loveqx/zabbix-doc/tree/master/zabbix-scripts/zabbix-template-clickhouse