灰度发布使用:
灰度服务管理服务:
依赖jar包
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-eureka</artifactId>
</dependency>
<dependency>
<groupId>cn.springcloud.gray</groupId>
<artifactId>spring-cloud-starter-gray-server</artifactId>
</dependency>
</dependencies>
application.yml
spring:
application:
name: gray-server
server:
port: 20202
eureka:
client:
register-with-eureka: true
fetch-registry: true
serviceUrl:
defaultZone: http://localhost:8080/eureka/
启动类添加@EnableGrayServer
@SpringBootApplication
@EnableEurekaClient
@EnableGrayServer
public class GrayServerApplication
{
public static void main( String[] args )
{
SpringApplication.run(GrayServerApplication.class,args);
}
}
业务服务端
依赖jar包
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-eureka</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-feign</artifactId>
</dependency>
<dependency>
<groupId>org.apache.commons</groupId>
<artifactId>commons-lang3</artifactId>
<version>3.5</version>
</dependency>
<dependency>
<groupId>cn.springcloud.gray</groupId>
<artifactId>spring-cloud-starter-gray</artifactId>
</dependency>
</dependencies>
application.yml
gray:
client:
instance:
grayEnroll: false #是否在启动后自动注册成灰度实例
serverUrl: http://localhost:20202 #灰度服务端的url
调用策略组方法:
POST /gray/manager/services/{serviceId}/instance/policyGroup
参数:
serviceId:service0
policyGroupFO:{
"alias": "1",
"enable": true,
"instanceId": "service0:8081",
"policies": [
{
"infos": {"v":"1"},
"policyId": "1",
"policyType": "REQUEST_PARAMETER"
}
],
"policyGroupId": "1"
}
上述策略描述的是: 对服务service0的service0:8081实例添加了策略组。当请求参数中有v=1时,请求路由到该实例。
以上参数中最重要的是:
serviceId,instanceId,infos,poliyType,policyGroupId.
serviceId:服务名
instanceId:服务名:端口号
infos:是一个map
policyType:枚举字符串,就四个值:
REQUEST_PARAMETER:请求参数策略
REQUEST_HEADER:请求头策略
REQUEST_IP :ip策略
CONTEXT_PARAMS 上下文参数策略