Sentinel Go 0.2.0 发布,完善易用性与开源生态

本文涉及的产品
云原生网关 MSE Higress,422元/月
任务调度 XXL-JOB 版免费试用,400 元额度,开发版规格
服务治理 MSE Sentinel/OpenSergo,Agent数量 不受限
简介:

Sentinel 是阿里巴巴开源的,面向分布式服务架构的流量控制组件,主要以流量为切入点,从限流、流量整形、熔断降级、系统自适应保护等多个维度来帮助开发者保障微服务的稳定性。Sentinel 承接了阿里巴巴近 10 年的双十一大促流量的核心场景,例如秒杀、冷启动、消息削峰填谷、集群流量控制、实时熔断下游不可用服务等,是保障微服务高可用的利器,原生支持 Java/Go/C++ 等多种语言,并且提供 Envoy 全局流控支持来为 Service Mesh 提供高可用防护的能力。

近期,Sentinel Go 0.2.0 正式发布,完善易用性与开源生态,新增 gRPC、Gin、Dubbo-go 等框架的适配,新增动态文件数据源支持。在 0.2.0 版本中,用户只需要简单地对 Sentinel 进行初始化,并且为框架配置 Sentinel 的适配即可快速接入。比如针对 Gin Web 服务,我们只需要以下几步即可快速接入 Sentinel:

1、在服务启动的时候对 Sentinel 进行初始化:

import (
    sentinel "github.com/alibaba/sentinel-golang/api"
)

func init() {
    err := sentinel.InitDefault()
    if err != nil {
        log.Fatal(err)
    }
}

2、在 Gin 的初始化代码中引入 SentinelMiddleware:

import (
    sentinelPlugin "github.com/alibaba/sentinel-golang/adapter/gin" 
    "github.com/gin-gonic/gin"
)

r := gin.New()
// Sentinel 会对每个 API route 进行统计,资源名称类似于 GET:/foo/:id
// 默认的限流处理逻辑是返回 429 (Too Many Requests) 错误码,支持配置自定义的 fallback 逻辑
r.Use(sentinelPlugin.SentinelMiddleware())

3、配置流控规则。可以创建动态文件数据源,通过文件配置规则,或硬编码配置规则。
详细特性列表请参考 Release Notes,欢迎大家使用并提出建议。

同时,社区也在完善更多的特性和整合模块,如 etcd 数据源、熔断降级等。Sentinel Go 版本的演进离不开社区的贡献,我们非常欢迎大家持续参与贡献,一起来主导未来版本的演进。若您有意愿参与贡献,可以参考 贡献指南 来入门,同时也欢迎联系我们加入 Sentinel 贡献小组认领任务(Sentinel 开源讨论钉钉群:30150716)。积极参与贡献的开发者我们会重点关注,有机会被提名为 Committer。Now start hacking!

相关文章
|
搜索推荐 Go 开发者
Go模块与依赖管理:构建稳定、可维护的项目生态
【2月更文挑战第9天】Go模块是Go语言从1.11版本开始引入的一个新的依赖管理工具,它改变了以往通过GOPATH管理项目依赖的方式,为Go开发者带来了更加灵活、高效的依赖管理方式。本文将深入探讨Go模块与依赖管理的概念、使用方法和最佳实践,帮助读者更好地理解和应用Go模块,构建稳定、可维护的项目生态。
|
5月前
|
人工智能 Kubernetes Java
回归开源,两位 Java 和 Go 程序员分享的开源贡献指引
Higress是一个基于Istio和Envoy的云原生API网关,支持AI功能扩展。它通过Go/Rust/JS编写的Wasm插件提供可扩展架构,并包含Node和Java的console模块。Higress起源于阿里巴巴,解决了Tengine配置重载及gRPC/Dubbo负载均衡问题,现已成为阿里云API网关的基础。本文介绍Higress的基本架构、功能(如AI网关、API管理、Ingress流量网关等)、部署方式以及如何参与开源贡献。此外,还提供了有效的开源贡献指南和社区交流信息。
553 33
|
SQL 关系型数据库 测试技术
技术经验分享:Go开源项目
技术经验分享:Go开源项目
118 0
|
11月前
|
NoSQL 测试技术 Go
自动化测试在 Go 开源库中的应用与实践
本文介绍了 Go 语言的自动化测试及其在 `go mongox` 库中的实践。Go 语言通过 `testing` 库和 `go test` 命令提供了简洁高效的测试框架,支持单元测试、集成测试和基准测试。`go mongox` 库通过单元测试和集成测试确保与 MongoDB 交互的正确性和稳定性,使用 Docker Compose 快速搭建测试环境。文章还探讨了表驱动测试、覆盖率检查和 Mock 工具的使用,强调了自动化测试在开源库中的重要性。
255 0
|
存储 Cloud Native Nacos
恭喜 Nacos 和 Sentinel 荣获 2023 开源创新榜“优秀开源项目”
恭喜 Nacos 和 Sentinel 荣获 2023 开源创新榜“优秀开源项目”
304 91
|
SQL 关系型数据库 MySQL
「Go开源」goose:深入学习数据库版本管理工具
「Go开源」goose:深入学习数据库版本管理工具
「Go开源」goose:深入学习数据库版本管理工具
|
缓存 JavaScript 前端开发
为开源项目 go-gin-api 增加 WebSocket 模块
为开源项目 go-gin-api 增加 WebSocket 模块
170 2
|
前端开发 JavaScript Go
|
关系型数据库 Go 开发工具
|
安全 Ubuntu 测试技术
庆祝 Go 开源发布十四周年!
庆祝 Go 开源发布十四周年!

热门文章

最新文章