這篇文章主要講解了“spring cloud consul中TtlScheduler的原理和作用是什么”,文中的講解內(nèi)容簡單清晰,易于學(xué)習(xí)與理解,下面請大家跟著小編的思路慢慢深入,一起來研究和學(xué)習(xí)“spring cloud consul中TtlScheduler的原理和作用是什么”吧!
創(chuàng)新互聯(lián)建站長期為成百上千客戶提供的網(wǎng)站建設(shè)服務(wù),團(tuán)隊(duì)從業(yè)經(jīng)驗(yàn)10年,關(guān)注不同地域、不同群體,并針對(duì)不同對(duì)象提供差異化的產(chǎn)品和服務(wù);打造開放共贏平臺(tái),與合作伙伴共同營造健康的互聯(lián)網(wǎng)生態(tài)環(huán)境。為茫崖企業(yè)提供專業(yè)的成都網(wǎng)站建設(shè)、網(wǎng)站制作,茫崖網(wǎng)站改版等技術(shù)服務(wù)。擁有十余年豐富建站經(jīng)驗(yàn)和眾多成功案例,為您定制開發(fā)。
本文主要研究一下spring cloud consul的TtlScheduler
spring-cloud-consul-discovery-2.1.2.RELEASE-sources.jar!/org/springframework/cloud/consul/discovery/TtlScheduler.java
public class TtlScheduler { private static final Log log = LogFactory.getLog(ConsulDiscoveryClient.class); private final MapserviceHeartbeats = new ConcurrentHashMap<>(); private final TaskScheduler scheduler = new ConcurrentTaskScheduler( Executors.newSingleThreadScheduledExecutor()); private HeartbeatProperties configuration; private ConsulClient client; public TtlScheduler(HeartbeatProperties configuration, ConsulClient client) { this.configuration = configuration; this.client = client; } @Deprecated public void add(final NewService service) { add(service.getId()); } /** * Add a service to the checks loop. * @param instanceId instance id */ public void add(String instanceId) { ScheduledFuture task = this.scheduler.scheduleAtFixedRate( new ConsulHeartbeatTask(instanceId), this.configuration .computeHearbeatInterval().toStandardDuration().getMillis()); ScheduledFuture previousTask = this.serviceHeartbeats.put(instanceId, task); if (previousTask != null) { previousTask.cancel(true); } } public void remove(String instanceId) { ScheduledFuture task = this.serviceHeartbeats.get(instanceId); if (task != null) { task.cancel(true); } this.serviceHeartbeats.remove(instanceId); } private class ConsulHeartbeatTask implements Runnable { private String checkId; ConsulHeartbeatTask(String serviceId) { this.checkId = serviceId; if (!this.checkId.startsWith("service:")) { this.checkId = "service:" + this.checkId; } } @Override public void run() { TtlScheduler.this.client.agentCheckPass(this.checkId); if (log.isDebugEnabled()) { log.debug("Sending consul heartbeat for: " + this.checkId); } } } }
TtlScheduler的構(gòu)造器接收HeartbeatProperties、ConsulClient;add方法會(huì)往scheduler注冊一個(gè)定時(shí)執(zhí)行的ConsulHeartbeatTask,執(zhí)行間隔由HeartbeatProperties的ttlValue及intervalRatio計(jì)算而來,同時(shí)如果previousTask不為null則對(duì)其進(jìn)行cancel;remove方法則cancel調(diào)用ScheduledFuture,然后將其從serviceHeartbeats中移除;ConsulHeartbeatTask的run方法則是執(zhí)行client.agentCheckPass
spring-cloud-consul-discovery-2.1.2.RELEASE-sources.jar!/org/springframework/cloud/consul/discovery/HeartbeatProperties.java
@ConfigurationProperties(prefix = "spring.cloud.consul.discovery.heartbeat") @Validated public class HeartbeatProperties { private static final Log log = org.apache.commons.logging.LogFactory .getLog(HeartbeatProperties.class); // TODO: change enabled to default to true when I stop seeing messages like // [WARN] agent: Check 'service:testConsulApp:xtest:8080' missed TTL, is now critical boolean enabled = false; @Min(1) private int ttlValue = 30; @NotNull private String ttlUnit = "s"; @DecimalMin("0.1") @DecimalMax("0.9") private double intervalRatio = 2.0 / 3.0; // TODO: did heartbeatInterval need to be a field? protected Period computeHearbeatInterval() { // heartbeat rate at ratio * ttl, but no later than ttl -1s and, (under lesser // priority), no sooner than 1s from now double interval = this.ttlValue * this.intervalRatio; double max = Math.max(interval, 1); int ttlMinus1 = this.ttlValue - 1; double min = Math.min(ttlMinus1, max); Period heartbeatInterval = new Period(Math.round(1000 * min)); log.debug("Computed heartbeatInterval: " + heartbeatInterval); return heartbeatInterval; } public String getTtl() { return this.ttlValue + this.ttlUnit; } public boolean isEnabled() { return this.enabled; } public void setEnabled(boolean enabled) { this.enabled = enabled; } public @Min(1) int getTtlValue() { return this.ttlValue; } public void setTtlValue(@Min(1) int ttlValue) { this.ttlValue = ttlValue; } public @NotNull String getTtlUnit() { return this.ttlUnit; } public void setTtlUnit(@NotNull String ttlUnit) { this.ttlUnit = ttlUnit; } public @DecimalMin("0.1") @DecimalMax("0.9") double getIntervalRatio() { return this.intervalRatio; } public void setIntervalRatio( @DecimalMin("0.1") @DecimalMax("0.9") double intervalRatio) { this.intervalRatio = intervalRatio; } @Override public String toString() { return new ToStringCreator(this).append("enabled", this.enabled) .append("ttlValue", this.ttlValue).append("ttlUnit", this.ttlUnit) .append("intervalRatio", this.intervalRatio).toString(); } }
HeartbeatProperties有ttlValue、intervalRatio等屬性,其computeHearbeatInterval方法會(huì)取ttlMinus1及Math.max(interval, 1)的最小值作為heartbeatInterval
spring-cloud-consul-discovery-2.1.2.RELEASE-sources.jar!/org/springframework/cloud/consul/discovery/ConsulDiscoveryClientConfiguration.java
@Configuration @ConditionalOnConsulEnabled @ConditionalOnProperty(value = "spring.cloud.consul.discovery.enabled", matchIfMissing = true) @ConditionalOnDiscoveryEnabled @EnableConfigurationProperties @AutoConfigureBefore({ SimpleDiscoveryClientAutoConfiguration.class, CommonsClientAutoConfiguration.class }) public class ConsulDiscoveryClientConfiguration { /** * Name of the catalog watch task scheduler bean. */ public static final String CATALOG_WATCH_TASK_SCHEDULER_NAME = "catalogWatchTaskScheduler"; @Autowired private ConsulClient consulClient; @Bean @ConditionalOnMissingBean @ConditionalOnProperty("spring.cloud.consul.discovery.heartbeat.enabled") // TODO: move to service-registry for Edgware public TtlScheduler ttlScheduler(HeartbeatProperties heartbeatProperties) { return new TtlScheduler(heartbeatProperties, this.consulClient); } @Bean @ConditionalOnMissingBean // TODO: move to service-registry for Edgware public HeartbeatProperties heartbeatProperties() { return new HeartbeatProperties(); } @Bean @ConditionalOnMissingBean // TODO: Split appropriate values to service-registry for Edgware public ConsulDiscoveryProperties consulDiscoveryProperties(InetUtils inetUtils) { return new ConsulDiscoveryProperties(inetUtils); } @Bean @ConditionalOnMissingBean public ConsulDiscoveryClient consulDiscoveryClient( ConsulDiscoveryProperties discoveryProperties) { return new ConsulDiscoveryClient(this.consulClient, discoveryProperties); } @Bean @ConditionalOnMissingBean @ConditionalOnProperty(name = "spring.cloud.consul.discovery.catalog-services-watch.enabled", matchIfMissing = true) public ConsulCatalogWatch consulCatalogWatch( ConsulDiscoveryProperties discoveryProperties, @Qualifier(CATALOG_WATCH_TASK_SCHEDULER_NAME) TaskScheduler taskScheduler) { return new ConsulCatalogWatch(discoveryProperties, this.consulClient, taskScheduler); } @Bean(name = CATALOG_WATCH_TASK_SCHEDULER_NAME) @ConditionalOnProperty(name = "spring.cloud.consul.discovery.catalog-services-watch.enabled", matchIfMissing = true) public TaskScheduler catalogWatchTaskScheduler() { return new ThreadPoolTaskScheduler(); } }
ConsulDiscoveryClientConfiguration在@ConditionalOnMissingBean以及@ConditionalOnProperty("spring.cloud.consul.discovery.heartbeat.enabled")的條件下會(huì)自動(dòng)注冊ttlScheduler
TtlScheduler的構(gòu)造器接收HeartbeatProperties、ConsulClient;add方法會(huì)往scheduler注冊一個(gè)定時(shí)執(zhí)行的ConsulHeartbeatTask,執(zhí)行間隔由HeartbeatProperties的ttlValue及intervalRatio計(jì)算而來,同時(shí)如果previousTask不為null則對(duì)其進(jìn)行cancel;remove方法則cancel調(diào)用ScheduledFuture,然后將其從serviceHeartbeats中移除;ConsulHeartbeatTask的run方法則是執(zhí)行client.agentCheckPass
感謝各位的閱讀,以上就是“spring cloud consul中TtlScheduler的原理和作用是什么”的內(nèi)容了,經(jīng)過本文的學(xué)習(xí)后,相信大家對(duì)spring cloud consul中TtlScheduler的原理和作用是什么這一問題有了更深刻的體會(huì),具體使用情況還需要大家實(shí)踐驗(yàn)證。這里是創(chuàng)新互聯(lián),小編將為大家推送更多相關(guān)知識(shí)點(diǎn)的文章,歡迎關(guān)注!