|
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