Commit 3a2823df by Nepxion

重构通过Rest方式实时版本路由功能

parent 3dfe2ca6
...@@ -17,6 +17,7 @@ import org.springframework.context.annotation.Configuration; ...@@ -17,6 +17,7 @@ import org.springframework.context.annotation.Configuration;
import com.nepxion.discovery.plugin.strategy.constant.StrategyConstant; import com.nepxion.discovery.plugin.strategy.constant.StrategyConstant;
import com.nepxion.discovery.plugin.strategy.extension.gateway.filter.GatewayStrategyFilter; import com.nepxion.discovery.plugin.strategy.extension.gateway.filter.GatewayStrategyFilter;
import com.nepxion.discovery.plugin.strategy.extension.gateway.impl.VersionDiscoveryEnabledAdapter;
@Configuration @Configuration
@AutoConfigureBefore(RibbonClientConfiguration.class) @AutoConfigureBefore(RibbonClientConfiguration.class)
...@@ -26,4 +27,9 @@ public class GatewayStrategyAutoConfiguration { ...@@ -26,4 +27,9 @@ public class GatewayStrategyAutoConfiguration {
public GatewayStrategyFilter gatewayStrategyFilter() { public GatewayStrategyFilter gatewayStrategyFilter() {
return new GatewayStrategyFilter(); return new GatewayStrategyFilter();
} }
@Bean
public VersionDiscoveryEnabledAdapter discoveryEnabledAdapter() {
return new VersionDiscoveryEnabledAdapter();
}
} }
\ No newline at end of file
...@@ -12,17 +12,31 @@ package com.nepxion.discovery.plugin.strategy.extension.gateway.impl; ...@@ -12,17 +12,31 @@ package com.nepxion.discovery.plugin.strategy.extension.gateway.impl;
import java.util.Map; import java.util.Map;
import org.apache.commons.lang3.StringUtils; import org.apache.commons.lang3.StringUtils;
import org.springframework.beans.factory.annotation.Autowired;
import com.nepxion.discovery.common.constant.DiscoveryConstant; import com.nepxion.discovery.common.constant.DiscoveryConstant;
import com.nepxion.discovery.common.util.JsonUtil; import com.nepxion.discovery.common.util.JsonUtil;
import com.nepxion.discovery.plugin.strategy.discovery.DiscoveryEnabledAdapter; import com.nepxion.discovery.plugin.strategy.discovery.DiscoveryEnabledAdapter;
import com.nepxion.discovery.plugin.strategy.discovery.DiscoveryEnabledExtension;
import com.nepxion.discovery.plugin.strategy.extension.gateway.context.GatewayStrategyContext; import com.nepxion.discovery.plugin.strategy.extension.gateway.context.GatewayStrategyContext;
import com.netflix.loadbalancer.Server; import com.netflix.loadbalancer.Server;
public class VersionDiscoveryEnabledAdapter implements DiscoveryEnabledAdapter { public class VersionDiscoveryEnabledAdapter implements DiscoveryEnabledAdapter {
@SuppressWarnings("unchecked") @Autowired(required = false)
private DiscoveryEnabledExtension discoveryEnabledExtension;
@Override @Override
public boolean apply(Server server, Map<String, String> metadata) { public boolean apply(Server server, Map<String, String> metadata) {
boolean enabled = applyVersion(server, metadata);
if (!enabled) {
return false;
}
return applyExtension(server, metadata);
}
@SuppressWarnings("unchecked")
private boolean applyVersion(Server server, Map<String, String> metadata) {
GatewayStrategyContext context = GatewayStrategyContext.getCurrentContext(); GatewayStrategyContext context = GatewayStrategyContext.getCurrentContext();
String versionJson = context.getExchange().getRequest().getHeaders().getFirst(DiscoveryConstant.VERSION); String versionJson = context.getExchange().getRequest().getHeaders().getFirst(DiscoveryConstant.VERSION);
if (StringUtils.isEmpty(versionJson)) { if (StringUtils.isEmpty(versionJson)) {
...@@ -47,4 +61,12 @@ public class VersionDiscoveryEnabledAdapter implements DiscoveryEnabledAdapter { ...@@ -47,4 +61,12 @@ public class VersionDiscoveryEnabledAdapter implements DiscoveryEnabledAdapter {
return false; return false;
} }
private boolean applyExtension(Server server, Map<String, String> metadata) {
if (discoveryEnabledExtension == null) {
return true;
}
return discoveryEnabledExtension.apply(server, metadata);
}
} }
\ No newline at end of file
...@@ -14,7 +14,7 @@ import org.springframework.boot.builder.SpringApplicationBuilder; ...@@ -14,7 +14,7 @@ import org.springframework.boot.builder.SpringApplicationBuilder;
import org.springframework.cloud.client.discovery.EnableDiscoveryClient; import org.springframework.cloud.client.discovery.EnableDiscoveryClient;
import org.springframework.context.annotation.Bean; import org.springframework.context.annotation.Bean;
import com.nepxion.discovery.plugin.example.gateway.extension.MyDiscoveryEnabledAdapter; import com.nepxion.discovery.plugin.example.gateway.extension.MyDiscoveryEnabledExtension;
@SpringBootApplication @SpringBootApplication
@EnableDiscoveryClient @EnableDiscoveryClient
...@@ -24,8 +24,8 @@ public class DiscoveryApplicationGateway { ...@@ -24,8 +24,8 @@ public class DiscoveryApplicationGateway {
} }
@Bean @Bean
public MyDiscoveryEnabledAdapter myDiscoveryEnabledAdapter() { public MyDiscoveryEnabledExtension myDiscoveryEnabledExtension() {
return new MyDiscoveryEnabledAdapter(); return new MyDiscoveryEnabledExtension();
} }
/*@Bean /*@Bean
......
...@@ -15,24 +15,17 @@ import org.apache.commons.lang3.StringUtils; ...@@ -15,24 +15,17 @@ import org.apache.commons.lang3.StringUtils;
import org.slf4j.Logger; import org.slf4j.Logger;
import org.slf4j.LoggerFactory; import org.slf4j.LoggerFactory;
import com.nepxion.discovery.plugin.strategy.discovery.DiscoveryEnabledExtension;
import com.nepxion.discovery.plugin.strategy.extension.gateway.context.GatewayStrategyContext; import com.nepxion.discovery.plugin.strategy.extension.gateway.context.GatewayStrategyContext;
import com.nepxion.discovery.plugin.strategy.extension.gateway.impl.VersionDiscoveryEnabledAdapter;
import com.netflix.loadbalancer.Server; import com.netflix.loadbalancer.Server;
// 实现了组合策略,版本路由策略+自定义策略 // 实现了组合策略,版本路由策略+自定义策略
// 如果不想要版本路由策略,请直接implements DiscoveryEnabledAdapter,实现自定义策略 public class MyDiscoveryEnabledExtension implements DiscoveryEnabledExtension {
public class MyDiscoveryEnabledAdapter extends VersionDiscoveryEnabledAdapter { private static final Logger LOG = LoggerFactory.getLogger(MyDiscoveryEnabledExtension.class);
private static final Logger LOG = LoggerFactory.getLogger(MyDiscoveryEnabledAdapter.class);
@Override @Override
public boolean apply(Server server, Map<String, String> metadata) { public boolean apply(Server server, Map<String, String> metadata) {
// 1.对Rest调用传来的Header的路由Version做策略。注意这个Version不是灰度发布的Version // 对Rest调用传来的Header参数(例如Token)做策略
boolean enabled = super.apply(server, metadata);
if (!enabled) {
return false;
}
// 2.对Rest调用传来的Header参数(例如Token)做策略
return applyFromHeader(server, metadata); return applyFromHeader(server, metadata);
} }
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment