CloudWeGo:云原生时代的微服务中间件

本文涉及的产品
应用实时监控服务-可观测链路OpenTelemetry版,每月50GB免费额度
容器镜像服务 ACR,镜像仓库100个 不限时长
可观测监控 Prometheus 版,每月50GB免费额度
简介: CloudWeGo 是字节跳动基础架构团队的开源项目,是一套可快速构建企业级云原生架构的中间件集合。企业级意味着项目面向企业级用户,从企业内部孵化出来,其特点是微服务通信与治理同时具备高性能、可扩展、高可靠三个突出性能,同时也非常注重用户体验和软件易用性。

CloudWeGo:云原生时代的微服务中间件

——罗广明

CloudWeGo开源负责人

一、项目总体介绍

image.png

CloudWeGo 是字节跳动基础架构团队开源项目,是一套可快速构建企业级原生架构中间件集合。企业级意味着项目面向企业级用户,从企业内部孵化出来,其特点是微服务通信与治理同时具备高性能、可扩展、高可靠三个突出性能,同时也非常注重用户体验和软件易用性。

image.png

CloudWeGo 项目都在字节内部经过大规模落地实践验证,开源后每一个功能迭代也第一时间在内部经过使用验证,是真正企业级落地项目,且开源用户和字节内部业务使用同一套服务框架。


CloudWeGo 提供各个子项目和相关功能,尤其是协议支持和服务治理等能力都是真正解决真实业务痛点而研发每一行代码优化都能实实在在用户带来性能和用户体验上提升。


此外, CloudWeGo 子项目研发设计也借鉴业界知名开源项目设计思路,同时将其他开源项目作为上游依赖。我们将 CloudWeGo 开源希望以此回馈开源社区,为开源社区贡献一份自己的力量,壮大开源社区生态。

image.png

CloudWeGo 在第一阶段开源四个项目,分别是 KitexNetpollThfitgoNetpoll-http2


Netpoll 是字节跳动内部自研高性能I/O 非阻塞专注于 RPC 场景的网络框架,借鉴业界开源 evio netty 优秀设计,具有非常出色性能,更适用于微服务架构。同时 Netpoll 还提供很多特性推荐在 RPC 框架中作为底层网络库使用享受特性带来性能收益。


Thfitgo 是由 Go 语言实现Thfit解析和代码生成器。支持非常完善Thfit IDL 语法和语义检查。相比于 Apache Thfit官方功能实现代码Thfitgo 问题修复,并且支持灵活插件机制,问题修复和语法语义检查部分内容当前也正在积极地反馈提交给上游Apache Thfit 社区。


Netpoll-http2是基于 Netpoll网络库 HTTP/2 实现。简而言之就是将 Golang 标准库里源码对于Go 使用替换为 netpoll,在 Kitex 里集成 Netpoll之后可以提供 gRPC 协议支持。

image.png

除这上述四个主要项目,CloudWeGo 还相继开源相关附属项目和中间件能力支持补充,满足用户需求,提升用户使用体验。比如CloudWeGo 提供kitex-examples 库,其中包含非常丰富的、开箱即用生产级别用例,包括服务治理 tracing链路追踪等。此外,还提供 benchmark 仓库,方便于用户基于仓库自行做 kitex netpoll 压测。同时开源thrift-gen-validator,支持 IDL 的语法语义检测用于做字段值校验,从而弥补 thrift 原生缺失能力。


截止到20225Kitext 已经收获 4300 starnetpoll收获 2600 star 整个 CloudWeGo 组织收获 star 数超 7000

image.png

CloudWeGo 的开源有几个关键时间节点。 2021 9 月正式对外发布CloudWeGo 项目开源,并在后续持续发版迭代修复 bug 开发新功能。2022 后,发版节奏趋于稳定,每两个月会发布一个中版本。


预计今年将发布Kitex 1.0.0 版本,这也意味着我们对外部正式承诺项目功能稳定性和完备性,用户可以放心将其投入生产环境。

image.png

CloudWeGo 的用户包括字节内部众多核心业务,如抖音、今日头条、飞书等,。此外项目开源以来也逐步吸引诸多外部企业用户关注很多企业在测试 CloudWeGo ,也有部分企业已经将 CloudWeGo 相关技术应用到生产环节,比如森马。


二、CloudWeGo-Kitex 介绍

image.png

上图为 Kitex项目架构,主要由三个部分构成分别是 Kitex ToolKitex Core以及依赖第三方库其中 Kitex Core是携带一整套微服务通信和治理能力 RPC 框架,也是 Kitex 核心部分Kitex Tool 是命令行工具,能够在命令行生成代码以及服务脚手架,可以提供非常便捷开发体验Second Party Pkg Kitex 依赖子项目 netpollNetpoll-http2 底层网络库除此之外还有 KitexByted 部分,它是字节内部基础设施扩展集合Kitex 通过这一套扩展集合支撑起内部业务发展。这也说明,字节内部外部共同依赖这一套 Kitex ToolKitex Core

image.png

Kitex 项目最重要的性是高性能和可扩展性,这也是贯穿整个 CloudWeGo 项目非常核心特点。


高性能方面,Kitex 框架默认集成了字节自研网络库 netpoll netpoll 性能相较于 Go 语言原生 gonet 非常显著优势。除网络库带来收益之外,我们还Thift 编解码做较多优化,感兴趣的读者可以观看字节以往发布的优化实践博客,也可以通过 Kitex benchmark 仓库了解相关性能测试数据和场景介绍。


扩展性方面, Kitex 在设计上做非常明确模块划分,提供了很多扩展接口以及默认扩展实现。使用者既可以根据自己需求自行定制相关扩展,可以结合默认扩展实现开箱即用效果。另外 Kitex 并没有硬耦合 Netpoll 网络库,开发者如果确有其他需求,也可以使用其他网络库扩展。


Kitex 的其他功能及特性还包括:

消息协议RPC 消息协议默认支持 Thrift Kitex 定制 Protobuf 协议以及 gRPC 协议。其中 Thrift 支持 Buffered Framed二进制协议Kitex Protobuf Kitex 自定义 Protobuf 协议,格式类似于 Thrift gRPC 则是针对 gRPC 消息协议支持,可以实现与 gRPC 框架互通。除此之外,用户也可以按需扩展自己消息协议。


传输协议封装上面消息协议进行 RPC 互通传输协议可以额外透传其他元信息用于服务治理。Kitex 支持传输协议有 TTheader http2 TTheader可以与 Thrift Kitex Protobuf 结合使用。http2 目前主要结合 gRPC协议使用,后续会实现 Thrift 协议的支持


消息类型目前支持 PingPongone way双向 streaming 等多种消息类型。其中Oneway 目前只对 Thrift 协议支持,双向Streaming 只对 gRPC 支持,后续会考虑支持Thrift 的双向 Streaming


 服务治理支持服务注册 / 发现、负载均衡、熔断、限流、重试、监控、链路跟踪、日志、诊断等服务治理模块,大部分均已提供默认扩展,使用者可选择集成。如果用户有其他诉求,比如需要集成自己内部注册中心内部链路追踪实现内部中心化限流接口等,都可以通过扩展实现,能够轻松地加载到业务代码中。


代码生成工具可支持生成ThriftProtobuf以及脚手架代码。原生 Thrift代码本次一起开源Thriftgo生成 Kitex Thrift 优化也由 Kitex2 作为插件支持。

image.png

归功于 Kitex 强大扩展能力,比如服务治理能力服务注册发现监控调用链日志CloudWeGo Kitex 团队在开源之际针对其原生能力都提供默认实现其他功能则由开源社区开发者自发地完成相关能力对接和支持。

image.png

上图为 Kitex 生态扩展汇总,几乎囊括业界所有主流服务注册与发现所需对接注册中心,比如 ConsulNacosetcd等。在可观性方面也先后支持OpenTracing OpenTelemetry未来计划主推 OpenTelemetry实现和对接。

image.png

Kitex 开源之后,也在积极地探索业界主流公有微服务产品做集成和对接。当前,阿里云已经对 Kitex 提供很好支持,旨在为用户提供微服务平台开发基座,保障开源用户能够在有需求情况下快速上云,同时保障服务稳定和平滑也尽量保障用户使用体验。


阿里云微服务引擎 MSE和应用实时监控 ARMS 已经对 Kitex 框架实现了集成和对接更多其他能力也在持续对接当中。此外,火山引擎相关微服务产品也在相关规划中完成将陆续开源。

image.png

CloudWeGo 联合阿里云哔哩哔哩Nacos 社区、 Spring Cloud Alibaba 社区以及 Dubbo 社区合作讨论服务治理标准化和规范化相关事宜共同成立发起 OpenSergo 项目。 OpenSergo 项目天然支持 Spring Cloud Apache Dubbo 等主流 Java 微服务框架,也支持 Kratos CloudWeGo Kitex 以及 Spring CloudAlibaba 等框架。


OpenSergo 统一治理规则用户不必再绑定到某具体开源方案上,也需绑定固定云厂商提供服务不同数据面和控制面只需对接 OpenSergo 即可无缝对接现有服务治理体系。


对于 CloudWeGo Kitex而言,支持或对接 OpenSergo  服务体系,除可以和其他开源框架在服务治理侧打平,也方便不同框架之间做相互迁移,并且服务侧的能力不会损失,可以在阿里云微服务引擎等产品和基础设施上快速上云。

image.png

Easy Note Kitex 项目的最佳实践之一它是笔记服务,使用 Kitex 来实现服务间 RPC 调用。入口处基于Hertz 对外提供 http 接口入口层以及服务间 RPC 通信完全使用 CloudWeGo技术栈,既可以对外提供 http接口,又能够保障内部 RPC 调用;既能支持 Thrift 通信,又能支持 Protobuf  通信协议。


第一版本的服务注册与发现使用了 ETCD 作为中心第二版本将替换成 Nacos,这也从侧面说明 Kitex 应用可以很方便进行服务注册中心选型和迁移。 ORM 库使用 Gorm 框架,网络库使用 netpoll 调用链追踪使用Jaeger 同时通过 OpenTelemetry进行埋点和数据上报,证明了 Kitex 可以与周边生态库做很好结合。


此外Easy Note 使用很多 Kitex 的其他功能,包括 Middleware 机制限流请求超时重试等服务治理能力以及基于 Thrift 连接多路复用


感兴趣用户可点击 http://github.com/cloudwego/kitex-examples查看样例更多详情,也可以参考样例快速构建自己微服务。


三、CloudWeGo 开源实践

image.png

CloudWeGo 开源之就非常重视官网建设和用户体验,官网默认支持英语页面文档,支持所有页面进行中英文切换,方便不同用户群体使用。同时官网的所有文档以及手册介绍都非常完备,包括 0 1 快速帮助新手上手

image.png

官网数据显示, CloudWeGo 官网用户遍布全球多国家,主要分布在中国、美国以及新加坡等地区,目前累计独立访问用户已超 20000

image.png

CloudWeGo 在开源社区建设方面也有一定经验,提供非常完备社区参与机制和身份晋升制度。开源爱好者可以通过开源社区加入到项目中来,同时也可以根据自己贡献度情况,成为晋升成为 Community Member Committer 此外在角色基础之上,还可晋升为项目 Approver ,能够行使代码 review 以及合并权利。感兴趣的同学可以通过访问 CloudWeGo 组织下Community仓库查看文档,了解更多详情。

image.png

此外,CloudWeGo 非常注重社区 Committer 培养和贡献激励。社区贡献者在晋升成为社区Member 或者 Committer 过程中,有社区管理委员会及字节跳动资深研发工程师进行一对一指导晋升流程公开透明,由管理会成员提名,再由CloudWeGo 开源委员公开在 github 上面投票通过。


目前 CloudWeGo 已经培养 5 Committer 他们也为社区发展做出非常重要贡献。

image.png

2022 年起,为缩短开发者距离更好地倾听来自于开发者的心声和诉求建议,我们将定期组织社区例会(目前为两周一次,同时为保证会议高效性,当前主要面向社区贡献者开放,感兴趣社区贡献可以社区联系,参与到例会中,共同为社区发展谏言献策,讨论技术方案或进行Q&A

image.png

除了社区建设,我们也在积极探索与外部其他机构合作。CloudWeGo 2021 10 月正式加入 CNCF Landscape为全球用户在 RPC 框架领域技术选型提供新选择,进一步丰富全球云原生领域开源生态。

image.png

同时,CloudWeGo 积极参与国内开源社区生态合作。我们加入了信通院可信开源社区,是可信开源社区第一批预备成员未来将积极参与信通院主导可信开源社区测评。

 

相关文章
|
1月前
|
Kubernetes Cloud Native 微服务
探索云原生技术:容器化与微服务架构的融合之旅
本文将带领读者深入了解云原生技术的核心概念,特别是容器化和微服务架构如何相辅相成,共同构建现代软件系统。我们将通过实际代码示例,探讨如何在云平台上部署和管理微服务,以及如何使用容器编排工具来自动化这一过程。文章旨在为开发者和技术决策者提供实用的指导,帮助他们在云原生时代中更好地设计、部署和维护应用。
|
4天前
|
运维 Cloud Native 应用服务中间件
阿里云微服务引擎 MSE 及 云原生 API 网关 2024 年 12 月产品动态
阿里云微服务引擎 MSE 面向业界主流开源微服务项目, 提供注册配置中心和分布式协调(原生支持 Nacos/ZooKeeper/Eureka )、云原生网关(原生支持Higress/Nginx/Envoy,遵循Ingress标准)、微服务治理(原生支持 Spring Cloud/Dubbo/Sentinel,遵循 OpenSergo 服务治理规范)能力。API 网关 (API Gateway),提供 APl 托管服务,覆盖设计、开发、测试、发布、售卖、运维监测、安全管控、下线等 API 生命周期阶段。帮助您快速构建以 API 为核心的系统架构.满足新技术引入、系统集成、业务中台等诸多场景需要
|
1月前
|
Cloud Native API 微服务
微服务引擎 MSE 及云原生 API 网关 2024 年 11 月产品动态
微服务引擎 MSE 及云原生 API 网关 2024 年 11 月产品动态。
|
1月前
|
运维 Cloud Native 应用服务中间件
阿里云微服务引擎 MSE 及 云原生 API 网关 2024 年 11 月产品动态
阿里云微服务引擎 MSE 面向业界主流开源微服务项目, 提供注册配置中心和分布式协调(原生支持 Nacos/ZooKeeper/Eureka )、云原生网关(原生支持Higress/Nginx/Envoy,遵循Ingress标准)、微服务治理(原生支持 Spring Cloud/Dubbo/Sentinel,遵循 OpenSergo 服务治理规范)能力。API 网关 (API Gateway),提供 APl 托管服务,覆盖设计、开发、测试、发布、售卖、运维监测、安全管控、下线等 API 生命周期阶段。帮助您快速构建以 API 为核心的系统架构.满足新技术引入、系统集成、业务中台等诸多场景需要
|
1月前
|
Kubernetes Cloud Native Docker
云原生之旅:从容器化到微服务
本文将带领读者踏上云原生的旅程,深入探讨容器化和微服务架构的概念、优势以及它们如何共同推动现代软件的发展。我们将通过实际代码示例,展示如何在Kubernetes集群上部署一个简单的微服务应用,并解释相关的配置和操作。无论你是云原生新手还是希望深化理解,这篇文章都将为你提供有价值的见解和实操指南。
|
1月前
|
Cloud Native API 持续交付
云原生时代的微服务架构设计
随着云计算的蓬勃发展,云原生概念逐渐成为IT行业的热点。本文将通过深入浅出的方式,介绍在云原生环境下,如何设计一个高效、可扩展的微服务架构。文章不仅涉及理论概念,还将结合实际代码示例,帮助读者理解微服务架构的核心要素和设计原则,以及如何在云平台上实现这些设计。
|
2月前
|
Kubernetes Cloud Native 开发者
云原生入门:从容器到微服务
本文将带你走进云原生的世界,从容器技术开始,逐步深入到微服务架构。我们将通过实际代码示例,展示如何利用云原生技术构建和部署应用。无论你是初学者还是有经验的开发者,这篇文章都将为你提供有价值的信息和启示。
|
2月前
|
消息中间件 运维 Cloud Native
云原生架构下的微服务优化策略####
本文深入探讨了云原生环境下微服务架构的优化路径,针对服务拆分、通信效率、资源管理及自动化运维等核心环节提出了具体的优化策略。通过案例分析与最佳实践分享,旨在为开发者提供一套系统性的解决方案,以应对日益复杂的业务需求和快速变化的技术挑战,助力企业在云端实现更高效、更稳定的服务部署与运营。 ####
|
1月前
|
Cloud Native API 持续交付
云原生架构下的微服务治理策略与实践####
本文旨在探讨云原生环境下微服务架构的治理策略,通过分析当前面临的挑战,提出一系列实用的解决方案。我们将深入讨论如何利用容器化、服务网格(Service Mesh)等先进技术手段,提升微服务系统的可管理性、可扩展性和容错能力。此外,还将分享一些来自一线项目的经验教训,帮助读者更好地理解和应用这些理论到实际工作中去。 ####
48 0
|
1月前
|
运维 Cloud Native 持续交付
深入理解云原生架构及其在现代企业中的应用
随着数字化转型的浪潮席卷全球,企业正面临着前所未有的挑战与机遇。云计算技术的迅猛发展,特别是云原生架构的兴起,正在重塑企业的IT基础设施和软件开发模式。本文将深入探讨云原生的核心概念、关键技术以及如何在企业中实施云原生策略,以实现更高效的资源利用和更快的市场响应速度。通过分析云原生架构的优势和面临的挑战,我们将揭示它如何助力企业在激烈的市场竞争中保持领先地位。