Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/code1986/sentinel-lib
annotation for using sentinel easy
https://github.com/code1986/sentinel-lib
Last synced: 2 months ago
JSON representation
annotation for using sentinel easy
- Host: GitHub
- URL: https://github.com/code1986/sentinel-lib
- Owner: code1986
- Created: 2019-06-06T06:35:12.000Z (over 5 years ago)
- Default Branch: master
- Last Pushed: 2023-04-17T19:08:01.000Z (almost 2 years ago)
- Last Synced: 2024-08-03T21:02:36.696Z (6 months ago)
- Language: Java
- Size: 18.6 KB
- Stars: 4
- Watchers: 1
- Forks: 1
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
- sentinel-awesome - Sentinel Rule Annotation Support - party library that supports configuring flow rule and degrade rule using annotation. Implemented by [code1986](https://github.com/code1986) (Extensions / Integrations)
README
# sentinel-lib 使用注解配置配置熔断限流规则
## 背景和目的- Sentinel的限流降级配置需要手动编码实现,定义限流熔断规则的地方往往和使用SentinelResource注解的代码不在同一个文件,配置分散不方便管理.
- ResourceName需要在SentinelResource中,降级的地方,限流的地方多处重复定义,可能会出现手误导致出错,为解决这些问题,sentinel-lib提供了一些注解,可以直接在使用SentinelResource注解的地方直接配置熔断限流规则.
## 如何使用
### 1. 编译项目
### 2. SpringBoot配置
如果是Spring Boot用户,可以通过`@EnableSentinel`注解开启包功能.注解生效时会自动注入Sentinel的`SentinelResourceAspect`类,所以**不需要**额外再配置.
例:
```java
@EnableSentinel
@SpringBootApplication
public class Starter extends SpringBootServletInitializer {public static void main(String[] args) throws Exception {
SpringApplication.run(Starter.class, args);
}
}
```### 3. Spring的xml配置
如果是基于xml的spring配置,需要配置如下这个两个bean.
```xml```
### 4. 可用的注解类简介
sentinel-lib库提供了多种流控配置注解和降级控制注解,如下| 注解类 | 功能 |
| -------- | ------- |
|FlowRuleDefine |默认直接拒绝行为的流控|
|RateLimitFlowRuleDefine| 限速流控|
|WarmUpFlowRuleDefine |预热和预热限速流控|
|DegradeRuleDefine |降级控制|### 5. 使用例子
```java
@RestController
@RequestMapping("sample")
public class MyFlowSampleController {
public String fallback() {
return "fallback";
}
public String blockHandler(BlockException ex) {
return "blocked!";
}
@WarmUpFlowRuleDefine
@FlowRuleDefine(count = "500")
@DegradeRuleDefine(count = "500", timeWindow = "10")
@SentinelResource(value="doSomething", blockHandler = "blockHandler", fallback = "fallback")
@RequestMapping("/doSomething")
public String doSomething() {
return new String("everything is ok");
}@RateLimitFlowRuleDefine
@FlowRuleDefine
@DegradeRuleDefine
@SentinelResource(value="exceptionApi", blockHandler = "blockHandler", fallback = "fallback")
@RequestMapping("/exceptionApi")
public Response exceptionApi() {
throw new RuntimeException("something is wrong!");
}
}
```### 6. 使用properties
注解中的配置可以支持properties文件.例如application.properties包含如下内容
```ini
my.flow=123
my.degrade.count=500
my.degrade.tw = 21
```则在注解中可以使用定义的变量,如下:
```java
@WarmUpFlowRuleDefine(rateLimit = "30")
@FlowRuleDefine(count = "${my.flow}")
@DegradeRuleDefine(count = "${my.degrade.count}", timeWindow = "${my.degrade.tw}")
@SentinelResource(value="doSomething", blockHandler = "myBlockHandler", fallback = "myDegradeHandler")
@RequestMapping("/doSomething")
public Response doSomething() {
return new Response("everything is ok");
}
```### 7. 关于灵活性
在注解中使用properties文件属性,可以支持在dev,test,prd环境使用不同的限流数量配置.如果需要更加灵活的在线实时修改配置能力,建议使用ASAH的Sentinel控制台来做.