|
1 | 1 | package cn.springcloud.gray;
|
2 | 2 |
|
3 |
| - |
| 3 | +import cn.springcloud.gray.client.config.properties.GrayLoadProperties; |
4 | 4 | import cn.springcloud.gray.decision.GrayDecisionFactoryKeeper;
|
5 | 5 | import cn.springcloud.gray.model.GrayInstance;
|
6 | 6 | import cn.springcloud.gray.model.GrayService;
|
|
16 | 16 | public class DefaultGrayManager extends AbstractCommunicableGrayManager {
|
17 | 17 |
|
18 | 18 | private Timer updateTimer = new Timer("Gray-Update-Timer", true);
|
| 19 | + private GrayLoadProperties grayLoadProperties; |
19 | 20 |
|
20 |
| - public DefaultGrayManager(GrayClientConfig grayClientConfig, GrayDecisionFactoryKeeper grayDecisionFactoryKeeper, |
21 |
| - List<RequestInterceptor> requestInterceptors) { |
| 21 | + public DefaultGrayManager( |
| 22 | + GrayClientConfig grayClientConfig, |
| 23 | + GrayLoadProperties grayLoadProperties, |
| 24 | + GrayDecisionFactoryKeeper grayDecisionFactoryKeeper, |
| 25 | + List<RequestInterceptor> requestInterceptors) { |
22 | 26 | super(grayClientConfig, grayDecisionFactoryKeeper, requestInterceptors);
|
| 27 | + this.grayLoadProperties = grayLoadProperties; |
| 28 | + |
| 29 | + |
23 | 30 | openForWork();
|
24 | 31 | }
|
25 | 32 |
|
26 |
| - |
27 | 33 | public void openForWork() {
|
28 | 34 | log.info("拉取灰度列表");
|
29 | 35 | doUpdate();
|
30 |
| - updateTimer.schedule(new UpdateTask(), |
31 |
| - getGrayClientConfig().getServiceUpdateIntervalTimerInMs(), |
32 |
| - getGrayClientConfig().getServiceUpdateIntervalTimerInMs()); |
| 36 | + int timerMs = getGrayClientConfig().getServiceUpdateIntervalTimerInMs(); |
| 37 | + if (timerMs > 0) { |
| 38 | + updateTimer.schedule( |
| 39 | + new UpdateTask(), |
| 40 | + getGrayClientConfig().getServiceUpdateIntervalTimerInMs(), |
| 41 | + getGrayClientConfig().getServiceUpdateIntervalTimerInMs()); |
| 42 | + } |
33 | 43 | }
|
34 | 44 |
|
35 |
| - |
36 | 45 | private void doUpdate() {
|
37 | 46 | try {
|
38 | 47 | log.debug("更新灰度服务列表...");
|
39 |
| - |
40 | 48 | List<GrayInstance> grayInstances = getGrayInformationClient().allGrayInstances();
|
41 | 49 | Map<String, GrayService> grayServices = new ConcurrentHashMap<>();
|
42 |
| - grayInstances.forEach(instance -> { |
43 |
| - updateGrayInstance(grayServices, instance); |
44 |
| - }); |
| 50 | + grayInstances.forEach( |
| 51 | + instance -> { |
| 52 | + updateGrayInstance(grayServices, instance); |
| 53 | + }); |
| 54 | + joinLoadedGrays(grayServices); |
45 | 55 | this.grayServices = grayServices;
|
46 | 56 | } catch (Exception e) {
|
47 | 57 | log.error("更新灰度服务列表失败", e);
|
48 | 58 | }
|
49 | 59 | }
|
50 | 60 |
|
51 | 61 |
|
| 62 | + /** |
| 63 | + * 加入配置文件中的灰度实例,但不会覆盖列表中的信息 |
| 64 | + * |
| 65 | + * @param grayServices 更新的灰度列表 |
| 66 | + */ |
| 67 | + private void joinLoadedGrays(Map<String, GrayService> grayServices) { |
| 68 | + if (grayLoadProperties != null && grayLoadProperties.isEnabled()) { |
| 69 | + grayLoadProperties.getGrayInstances().forEach( |
| 70 | + instance -> { |
| 71 | + if (grayServices.containsKey(instance.getServiceId()) |
| 72 | + || grayServices.get(instance.getServiceId()) |
| 73 | + .getGrayInstance(instance.getInstanceId()) != null) { |
| 74 | + updateGrayInstance(grayServices, instance); |
| 75 | + } |
| 76 | + }); |
| 77 | + } |
| 78 | + } |
| 79 | + |
52 | 80 | class UpdateTask extends TimerTask {
|
53 | 81 |
|
54 | 82 | @Override
|
55 | 83 | public void run() {
|
56 | 84 | doUpdate();
|
57 | 85 | }
|
58 | 86 | }
|
59 |
| - |
60 |
| - |
61 | 87 | }
|
0 commit comments