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

本文涉及的产品
服务治理 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!

相关文章
|
20天前
|
JSON 缓存 物联网
推荐一款go语言的开源物联网框架-opengw
推荐一款go语言的开源物联网框架-opengw
30 4
|
1月前
|
SQL Go 数据库
【Sentinel Go】新手指南、流量控制、熔断降级和并发隔离控制
【2月更文挑战第12天】随着微服务的流行,服务和服务之间的稳定性变得越来越重要。Sentinel 是面向分布式、多语言异构化服务架构的流量治理组件,主要以流量为切入点,从流量路由、流量控制、流量整形、熔断降级、系统自适应过载保护、热点流量防护等多个维度来帮助开发者保障微服务的稳定性。
57 0
|
3月前
|
存储 Cloud Native Nacos
恭喜 Nacos 和 Sentinel 荣获 2023 开源创新榜“优秀开源项目”
恭喜 Nacos 和 Sentinel 荣获 2023 开源创新榜“优秀开源项目”
|
7月前
|
弹性计算 Dubbo 应用服务中间件
快速玩转Dubbo生态之限流降级篇(Sentinel)
本课程将对 Dubbo 接入限流降级的方式进行介绍,通过对本节课程的学习,可以快速上手 Dubbo 接入 Sentinel 生态。
147 0
|
8月前
|
NoSQL Go Redis
Asynq: 基于Redis实现的Go生态分布式任务队列和异步处理库
Asynq: 基于Redis实现的Go生态分布式任务队列和异步处理库
284 0
|
9月前
|
Go 开发者
[Go开源工具] go-optioner:轻松生成函数选项模式代码
你是否使用过 functional options 函数选项模式?在使用时,你是否遇到过多字段的结构体而需要手动编写大量的设置选项函数的代码? 本文介绍了 go-opioner 开源工具的安装和使用,它能够根据结构体的定义,自动生成函数选项模式的代码。
90 0
|
10月前
|
边缘计算 BI Go
Go开源库Excelize介绍,电子Excel表格操作强大的库
Go开源库Excelize介绍,电子Excel表格操作强大的库
|
设计模式 缓存 Java
高德Go生态的服务稳定性建设|性能优化的实战总结
目前go语言不仅在阿里集团内部,在整个互联网行业内也越来越流行,本文把高德过去go服务开发中的性能调优经验进行总结和沉淀,希望能为正在使用go语言的同学在性能优化方面带来一些参考价值。
22935 5
高德Go生态的服务稳定性建设|性能优化的实战总结
|
网络协议 安全 API
玩转 Go 生态|Hertz WebSocket 扩展简析
WebSocket 是一种可以在单个 TCP 连接上进行全双工通信,位于 OSI 模型的应用层。WebSocket 使得客户端和服务器之间的数据交换变得更加简单,允许服务端主动向客户端推送数据。
315 0
玩转 Go 生态|Hertz WebSocket 扩展简析
|
JSON 编译器 Go
我开源了一个Go学习仓库|笔记分享(三)
学习Go半年之后,我决定重新开始阅读《The Go Programing Language》,对书中涉及重点进行全面讲解,这是Go语言知识查漏补缺系列的文章第三篇。
102 0
我开源了一个Go学习仓库|笔记分享(三)