FlieBeat & Kafka & Clickhouse 替代ELK 系列一

背景

saas服务未来会面临数据安全、合规等问题。公司的业务需要沉淀一套私有化部署能力,帮助业务提升行业竞争力。为了完善平台系统能力、我们需要沉淀一套数据体系帮助运营分析活动效果、提升运营能力。然而在实际的开发过程中,如果直接部署一套大数据体系,对于使用者来说将是一笔比较大的服务器开销。为此我们选用折中方案完善数据分析能力。

elasticsearch vs clickhouse

ClickHouse是一款高性能列式分布式数据库管理系统,我们对ClickHouse进行了测试,发现有下列优势:

ClickHouse写入吞吐量大,单服务器日志写入量在50MB到200MB/s,每秒写入超过60w记录数,是ES的5倍以上。在ES中比较常见的写Rejected导致数据丢失、写入延迟等问题,在ClickHouse中不容易发生。

查询速度快,官方宣称数据在pagecache中,单服务器查询速率大约在2-30GB/s;没在pagecache的情况下,查询速度取决于磁盘的读取速率和数据的压缩率。经测试ClickHouse的查询速度比ES快5-30倍以上。

ClickHouse比ES服务器成本更低。一方面ClickHouse的数据压缩比比ES高,相同数据占用的磁盘空间只有ES的1/3到1/30,节省了磁盘空间的同时,也能有效的减少磁盘IO,这也是ClickHouse查询效率更高的原因之一;另一方面ClickHouse比ES占用更少的内存,消耗更少的CPU资源。我们预估用ClickHouse处理日志可以将服务器成本降低一半。

在这里插入图片描述

支持功能\开源项目 ElasticSearch ClickHouse
查询 java c++
存储类型 文档存储 列式数据库
分布式支持 分片和副本都支持 分片和副本都支持
扩展性
写入速度
CPU/内存占用
存储占用(54G日志数据导入) 高 94G(174%) 低 23G(42.6%)
精确匹配查询速度 一般
模糊匹配查询速度
权限管理 支持 支持
查询难度
可视化支持
使用案例 很多 携程
维护难度

成本分析

备注:在没有任何折扣的情况下,基于aliyun分析

成本项 标准 费用 说明 总费用
zookeeper 集群 2核4g 共享计算型 n4 50G SSD 云盘 222/月 3台高可用 666/月
kafka 集群 4核 8g 共享标准型 s650G SSD 云盘300G 数据盘 590/月 3台高可用 1770/月
filebeat 部署 混部相关的应用,会产生一定的内存以及磁盘开销,对应用的可用性会造成一定的影响。
clickhouse 16核32g 共享计算型 n450G SSD 云盘1000G 数据盘 2652/月 2台高可用 5304/月
总费用 7740/月

环境部署

zookeeper 集群部署

在这里插入图片描述


yum install java-1.8.0-openjdk-devel.x86_64
/etc/profile 配置环境变量
更新系统时间
yum install  ntpdate
ntpdate asia.pool.ntp.org

mkdir zookeeper
mkdir ./zookeeper/data
mkdir ./zookeeper/logs

wget  --no-check-certificate https://mirrors.tuna.tsinghua.edu.cn/apache/zookeeper/zookeeper-3.7.1/apache-zookeeper-3.7.1-bin.tar.gz
tar -zvxf apache-zookeeper-3.7.1-bin.tar.gz -C /usr/zookeeper

export ZOOKEEPER_HOME=/usr/zookeeper/apache-zookeeper-3.7.1-bin
export PATH=$ZOOKEEPER_HOME/bin:$PATH

进入ZooKeeper配置目录
cd $ZOOKEEPER_HOME/conf

新建配置文件
vi zoo.c
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
ClickHouse是一个高性能的列式数据库管理系统,可以与各种数据源进行集成,包括Kafka消息队列。集成Kafka可以让ClickHouse实时消费Kafka中的数据,并将其存储到ClickHouse中进行分析和查询。下面是将ClickHouse集成Kafka的一些步骤: 1. 安装KafkaClickHouse 首先要安装KafkaClickHouseKafka可以从官网下载最新版本的程序包。ClickHouse也可以从官网下载相应的程序包进行安装。 2. 创建Kafka主题 在Kafka中创建一个主题,用于存储要传输到ClickHouse的数据。可以使用Kafka自带的命令行工具创建主题。例如: ``` bin/kafka-topics.sh --create --zookeeper localhost:2181 --replication-factor 1 --partitions 1 --topic clickhouse_topic ``` 3. 安装Kafka引擎插件 ClickHouse提供了Kafka引擎插件,可以通过它与Kafka进行集成。可以从ClickHouse官网下载最新的引擎插件,并将其安装到ClickHouse中。安装完成后,需要重新启动ClickHouse服务。 4. 创建表 在ClickHouse中创建表,用于存储从Kafka中读取的数据。可以使用以下命令创建表: ``` CREATE TABLE kafka_table (key String, value String) ENGINE = Kafka('localhost:9092', 'clickhouse_topic', 'group1', 'JSONEachRow'); ``` 其中,'localhost:9092'是Kafka集群的地址,'clickhouse_topic'是要消费的主题名称,'group1'是消费者组的名称,'JSONEachRow'表示从Kafka中读取的消息是JSON格式。 5. 查询数据 在ClickHouse中使用SELECT语句查询从Kafka中读取的数据。例如: ``` SELECT * FROM kafka_table; ``` 这将返回存储在kafka_table表中的所有数据。 以上是将ClickHouse集成Kafka的基本步骤,可以根据具体情况进行调整和优化。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值