欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Nacos服務(wù)發(fā)現(xiàn)并發(fā)啟動(dòng)scheduleUpdate定時(shí)任務(wù)的流程分析

 更新時(shí)間:2023年02月23日 09:18:17   作者:禿禿愛健身  
這篇文章主要介紹了Nacos服務(wù)發(fā)現(xiàn)并發(fā)啟動(dòng)scheduleUpdate定時(shí)任務(wù),本文結(jié)合實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下

一、前言

博主今天復(fù)習(xí)Nacos源碼的時(shí)候,發(fā)現(xiàn)了一個(gè)算是有意思的細(xì)節(jié)點(diǎn),這里分享一下。

二、服務(wù)發(fā)現(xiàn)“懶加載”機(jī)制

當(dāng)nacos客戶端運(yùn)?起來之后,它只是去做服務(wù)注冊(cè)、配置獲取等操作;并不會(huì)立即去請(qǐng)求服務(wù)信息;當(dāng)?shù)谝淮握?qǐng)求時(shí)候,才會(huì)去獲取服務(wù),即懶加載機(jī)制;

1、服務(wù)發(fā)現(xiàn)流程

Client端做服務(wù)發(fā)現(xiàn)時(shí),無論是否能從本地緩存中獲取到服務(wù)實(shí)例信息,都會(huì)啟動(dòng)一個(gè)定時(shí)任務(wù)(每秒做一次服務(wù)實(shí)例信息的更新)。然而由于可能多個(gè)請(qǐng)求同時(shí)要做服務(wù)發(fā)現(xiàn),這樣總不能每一次做服務(wù)發(fā)現(xiàn)時(shí)都去啟動(dòng)一個(gè)定時(shí)任務(wù)做服務(wù)實(shí)例信息更新吧。所以肯定要有一個(gè)機(jī)制去確保針對(duì)某一個(gè)Cluster下的Service,當(dāng)前Client只會(huì)啟動(dòng)一個(gè)定時(shí)任務(wù)。

2、HostReactor#scheduleUpdateIfAbsent()

HostReactor#scheduleUpdateIfAbsent()方法負(fù)責(zé)啟動(dòng)做服務(wù)實(shí)例信息更新的定時(shí)任務(wù)。
從方法名也能看出來:是當(dāng)定時(shí)任務(wù)不存在時(shí),才會(huì)啟動(dòng)一個(gè)定時(shí)任務(wù)。

private final Map<String, ScheduledFuture<?>> futureMap = new HashMap<String, ScheduledFuture<?>>();

public void scheduleUpdateIfAbsent(String serviceName, String clusters) {
    if (futureMap.get(ServiceInfo.getKey(serviceName, clusters)) != null) {
        return;
    }
    
    synchronized (futureMap) {
        if (futureMap.get(ServiceInfo.getKey(serviceName, clusters)) != null) {
            return;
        }
        
        ScheduledFuture<?> future = addTask(new UpdateTask(serviceName, clusters));
        futureMap.put(ServiceInfo.getKey(serviceName, clusters), future);
    }
}

看一下這個(gè)代碼邏輯:

  • 為了防止一個(gè)實(shí)例開啟多個(gè)這種定時(shí)任務(wù),會(huì)用一個(gè)Map來去重,針對(duì)這個(gè)Map的數(shù)據(jù)添加會(huì)采用一個(gè)類似雙重檢查鎖的機(jī)制,確保Map添加數(shù)據(jù)的線程安全性。
  • 如果futureMap中已經(jīng)有了當(dāng)前服務(wù),則方法直接返回。
  • 這一步是為了減少不必要的同步操作。
  • 否則,對(duì)futureMap對(duì)象加synchronized鎖;同步代碼塊需要再進(jìn)一步判斷futureMap不為空。
  • 因?yàn)樵诙嗑€程并發(fā)場景下,可能多個(gè)線程判斷futureMap中都沒有當(dāng)前服務(wù),都進(jìn)入到同步代碼塊,一個(gè)線程進(jìn)入同步代碼塊,將當(dāng)前服務(wù)添加到futureMap中。
  • 其他線程獲取到鎖之后再進(jìn)入到同步代碼塊,再次判斷futureMap中是否含有當(dāng)前服務(wù),如果含有,則方法直接返回。
  • 假如同步代碼中不判空,會(huì)重復(fù)執(zhí)行將當(dāng)前服務(wù)添加到futureMap中的操作。

既然是DCL的變種版,為了futureMap沒有被volatile關(guān)鍵字修飾,不會(huì)有指令重排序的問題嗎?

  • 并不會(huì),futureMap.put()是Map的添加數(shù)據(jù)操作,和對(duì)象初始化是兩種場景。

3、DCL

Double check Lock確保類單例的代碼如下:

public class DoubleCheckLazySingleton {

    private volatile static DoubleCheckLazySingleton singleton;

    private DoubleCheckLazySingleton() {
    }

    public DoubleCheckLazySingleton getSingleton() {
        if (singleton == null) {
            synchronized (this) {
                //只有在singleton為null的時(shí)候才創(chuàng)建實(shí)例
                if (singleton == null) {
                    singleton = new DoubleCheckLazySingleton();
                }
            }
        }
        return singleton;
    }
}

到此這篇關(guān)于Nacos服務(wù)發(fā)現(xiàn)并發(fā)啟動(dòng)scheduleUpdate定時(shí)任務(wù)的文章就介紹到這了,更多相關(guān)Nacos服務(wù)發(fā)現(xiàn)內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • SpringBoot數(shù)據(jù)庫初始化datasource配置方式

    SpringBoot數(shù)據(jù)庫初始化datasource配置方式

    這篇文章主要為大家介紹了SpringBoot數(shù)據(jù)庫初始化datasource配置方式,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-12-12
  • Java1.8中StringJoiner的使用及源碼詳析

    Java1.8中StringJoiner的使用及源碼詳析

    在看String類時(shí),看到有使用StringJoiner類,所以順便看了下StringJoiner類,下面這篇文章主要給大家介紹了關(guān)于Java 1.8中StringJoiner的使用及源碼分析的相關(guān)資料,需要的朋友可以參考借鑒,下面來一起看看吧
    2018-08-08
  • MyBatis的五種批量插入詳解

    MyBatis的五種批量插入詳解

    這篇文章主要介紹了MyBatis的五種批量插入詳解,MyBatis是一款半自動(dòng)的ORM持久層框架,具有較高的SQL靈活性,支持高級(jí)映射(一對(duì)一,一對(duì)多),動(dòng)態(tài)SQL,延遲加載和緩存等特性,但它的數(shù)據(jù)庫無關(guān)性較低,需要的朋友可以參考下
    2023-08-08
  • java定義數(shù)組的三種類型總結(jié)

    java定義數(shù)組的三種類型總結(jié)

    下面小編就為大家?guī)硪黄猨ava定義數(shù)組的三種類型總結(jié)。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2016-10-10
  • spring?boot對(duì)敏感信息進(jìn)行加解密的項(xiàng)目實(shí)現(xiàn)

    spring?boot對(duì)敏感信息進(jìn)行加解密的項(xiàng)目實(shí)現(xiàn)

    本文主要介紹了spring?boot對(duì)敏感信息進(jìn)行加解密的項(xiàng)目實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-04-04
  • Java list如何根據(jù)id獲取子節(jié)點(diǎn)

    Java list如何根據(jù)id獲取子節(jié)點(diǎn)

    這篇文章主要介紹了Java list如何根據(jù)id獲取子節(jié)點(diǎn),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-03-03
  • 詳解Java中的BigDecimal

    詳解Java中的BigDecimal

    這篇文章主要介紹了Java中的BigDecimal的使用方法,幫助大家更好的理解和使用Java,感興趣的朋友可以了解下
    2020-09-09
  • java 線程池的實(shí)現(xiàn)原理、優(yōu)點(diǎn)與風(fēng)險(xiǎn)、以及4種線程池實(shí)現(xiàn)

    java 線程池的實(shí)現(xiàn)原理、優(yōu)點(diǎn)與風(fēng)險(xiǎn)、以及4種線程池實(shí)現(xiàn)

    這篇文章主要介紹了java 線程池的實(shí)現(xiàn)原理、優(yōu)點(diǎn)與風(fēng)險(xiǎn)、以及4種線程池實(shí)現(xiàn)包括了:配置線程池大小配置,線程池的實(shí)現(xiàn)原理等,需要的朋友可以參考下
    2023-02-02
  • 詳解SpringBoot如何使用Redis和Redis緩存

    詳解SpringBoot如何使用Redis和Redis緩存

    這篇文章主要為大家詳細(xì)介紹了SpringBoot如何使用Redis和Redis緩存,文中的示例代碼講解詳細(xì),對(duì)我們學(xué)習(xí)SpringBoot有一定的幫助,需要的可以參考一下
    2022-06-06
  • 圖解分析Javaweb進(jìn)程與線程

    圖解分析Javaweb進(jìn)程與線程

    這篇文章主要介紹了Javaweb進(jìn)程與線程的知識(shí),本篇文章通過簡要的案例,講解了它的基礎(chǔ)原理與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下
    2022-03-03

最新評(píng)論