前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >腾讯云 Serverless 云函数实现 CKafka 数据转存到 ES

腾讯云 Serverless 云函数实现 CKafka 数据转存到 ES

作者头像
腾讯云serverless团队
发布2020-08-10 10:11:34
9310
发布2020-08-10 10:11:34
举报

背景介绍

腾讯云 Serverless 云函数是下一代通用计算平台,提供安全稳定、高效易用的低成本无服务器运行环境。随着 Kafka 社区的繁荣,越来越多的用户开始使用 Kafka 来做日志收集、大数据分析、流式数据处理等。而公有云上的产品 Ckafka 也借助了开源社区的力量,做了很多优化:

  • 基于 ApacheKafka 的分布式、高可扩展、高吞吐
  • 100% 兼容 Apache KafkaAPI(0.9 及 0.10)
  • 无需部署,直接使用 Kafka 所有功能
  • ckafka 封装所有集群细节,无需用户运维
  • 支持动态升降实例配置,按照需求付费(开发中)
  • 对消息引擎优化,性能比社区最高提升 50%

同时,在公有云上,云函数也和 CKafka 做了深度联动,并推出了很多非常实用的功能。

运行原理

如下图,云函数可以实时消费 Ckafka 中的消息,比如做数据转存、日志清洗、实时消费等。并且,像数据转存的功能已经集成到了 Ckafka 的控制台上,用户可以一键开启使用,大大降低了用户使用的复杂度。

方案优势

对比使用云主机自建 Ckafka Consumer 的方式,云函数帮用户屏蔽掉了很多不必要的开销:

  1. 云函数控制台上可以一键开启Ckafka触发器,帮助用户自动创建 Consumer,并由云函数平台来维护组建的高可用;
  2. Ckafka 触发器自身支持很多实用的配置:支持配置 offset 位置、支持配置1~1万消息聚合条数、支持配置 1~1万次重试次数等;
  3. 基于云函数开发的业务逻辑,天然支持弹性伸缩,无需额外搭建和维护服务器集群等。

常用场景

如下图所示,借助云函数和 Ckafka 触发器,可以非常方便实现 CKafka 消息转存到 COS、ES、DB等,那本次也会借助云函数来替代 Logstash,实现 Ckafka 消息罗盘 ES。

和使用 CVM 自建 Logstash 对比,云函数有以下优势:

  1. 云函数自带 Consumer 组件,可自行聚合;
  2. 云函数的模板函数已经实现了消息聚合和部分清洗能力,还可自行扩展;
  3. 云函数集群自带高可用和监控日志能力,业务上线速度更快;
  4. 云函数采用按实际使用收费,比自建集群费用更优,可以节省 50% 的费用。

部署流程

前置条件

以广州地域为例:

  • 开启 Elasticsearch 服务
  • 开启 Ckafka 服务

1. 创建云函数

登录云函数控制台,选择地域后,新建函数,选择运行环境Python3.6,搜索“Ckafka”,选中模板函数后,下一步。

在下一步中,点开高级设置:配置环境变量,如下:

必填参数:ES_Address,ES_User,ES_Password,ES_Index_KeyWord

可选填入:

ES_Log_IgnoreWord(需要删除的关键词,缺省则全量写入,如填name,password)

ES_Index_TimeFormat(按照天或者小时设置Index,缺省则按照天建立索引,如填hour)

在高级设置中,配置私有网络,需要选择和 ES 相同 VPC,完成函数创建。

2. 创建 Ckafka 触发器

在函数的【触发管理】页面,创建触发器,配置对应 Topic 的触发方式,提交后即可生效。

3. 查看 ES 和函数运行日志

  • 查看函数运行日志

查看函数运行日志

  • 查看 Kibana

查看 Kibana

  • 扩展能力介绍

如果想要实现高级日志清洗逻辑,可直接在函数代码中修改逻辑。

针对函数的运行状态,可以自行配置监控告警,实时感知业务运行情况。

One More Thing

立即体验腾讯云 Serverless Demo,获取免费试用额度,请在 PC 端访问:

serverless.cloud.tencent.com/start?c=wx

本文参与 腾讯云自媒体分享计划,分享自微信公众号。
原始发表:2020-08-07,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 ServerlessCloudNative 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 背景介绍
  • 运行原理
  • 方案优势
  • 常用场景
  • 部署流程
  • One More Thing
相关产品与服务
云函数
云函数(Serverless Cloud Function,SCF)是腾讯云为企业和开发者们提供的无服务器执行环境,帮助您在无需购买和管理服务器的情况下运行代码。您只需使用平台支持的语言编写核心代码并设置代码运行的条件,即可在腾讯云基础设施上弹性、安全地运行代码。云函数是实时文件处理和数据处理等场景下理想的计算平台。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档