我们项目在后面引入流量染色,说是为了配合后面要实行的git-flow升级改造的落地,每个feature分支带上对应tag,比如tag是自己的名称,前端请求也带上对应tag联调,对应到具体人和要联调的服务。 git-flow的回顾可以点这里
我们架构同事跟我们介绍流量染色
什么是流量染色
在
HTTP
请求中,加入对应环境,用户等变量信息,使请求可以根据这些信息做分类,转发等操作
为什么需要流量染色
1.
使不同的服务,共享环境
2.
可以本地调试特定的服务,而不阻碍服务的正常运行
3.
统计分析
我个人觉得可能主要是第2、3点吧,第一点是说不同的服务设置相同的tag,就可以达到共享环境的目的了吧。
使用方法
1.启动服务时为服务上色
2.客户端请求时 指定颜色
Tag
的
Header
大概的流程是这样的,请求过来后到ColorFilter,从euraka中根据tag拿到服务信息
根据当前服务请求次和服务个数取余拿到对应的服务id,转发到那个服务
这里我有个小疑问:如果tag都是唯一的,任何数和1取余数都是本身,这里不会有问题吗?
int id = requestCounter.incrementAndGet() % instanceInfos.size();
如果是调用feign,在FeignColoredInterceptor被拦截,然后把当前服务的tag带上去
虽然没有实际应用,但感觉流量染色还是挺有用的。如果后面要用,可以参考