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

springboot 注冊服務注冊中心(zk)的兩種方式詳解

 更新時間:2018年01月09日 13:40:20   作者:扎心了老鐵  
本文通過一個demo講述一下這兩種注冊方式,使用的是傳統(tǒng)的向zk注冊的方案。對springboot 注冊zk的相關知識感興趣的朋友一起看看吧

在使用springboot進行開發(fā)的過程中,我們經常需要處理這樣的場景:在服務啟動的時候,需要向服務注冊中心(例如zk)注冊服務狀態(tài),以便當服務狀態(tài)改變的時候,可以故障摘除和負載均衡。

我遇到過兩種注冊的途徑:

1、在Spring的webapplication啟動完成后,直接進行注冊;

2、在servlet容器啟動完成后,通過listener進行注冊。

本文通過一個demo講述一下這兩種注冊方式,使用的是傳統(tǒng)的向zk注冊的方案。

1、Spring webapplication啟動完成后注冊

先上代碼看一下

@SpringBootApplication
public class WebApplication {
 private static final Logger logger = LoggerFactory.getLogger(WebApplication.class);
 private static volatile boolean IS_REGISTRY = false;
 public static void main(String[] args) {
 ApplicationContext context = run(WebApplication.class, args);
 if (IS_REGISTRY) {
  logger.info("注冊2: WebApplication啟動完成后");
  ZkClient zkClient = context.getBean(ZkClient.class);
  zkClient.register();
  IS_REGISTRY = true;
  logger.info("注冊2: 注冊成功");
 }
 }
}

這里,我們在WebApplication中,獲取zkClient,并進行注冊。

這里需要說明一點,我們這里通過ApplicationContext來獲取zkClient的bean,原因是在webApplication的初始化過程中你不能用Autowired的方式注入Bean,因為在webApplication啟動過程中才會讀所有的configuration并將bean初始化完成,在沒有完成初始化之前,你不能注入bean。

關于注冊的詳細代碼這里不展開了。

2、在servlet容器初始化完成后,通過listener的方式進行注冊

照樣先上代碼

@WebListener
public class RegisterListener implements ServletContextListener {
 protected final Logger logger = LoggerFactory.getLogger(this.getClass());
 private static volatile boolean IS_REGISTRY = false;
 @Autowired
 private ZkClient zkClient;
 @Override
 public void contextInitialized(ServletContextEvent servletContextEvent) {
 try {
  if (!IS_REGISTRY) {
  logger.info("注冊1: Servelet容器啟動成功后");
  zkClient.register();
  logger.info("注冊1: 注冊成功");
  }
  IS_REGISTRY = true;
 } catch (Exception e) {
  IS_REGISTRY = false;
  logger.info("注冊1: 注冊失敗");
 }
 }
 @Override
 public void contextDestroyed(ServletContextEvent servletContextEvent) {
 if (IS_REGISTRY) {
  zkClient.stop();
 }
 }
}

你需要先寫一個listener,這個listener實現ServletContextListener接口,并且用@WebListener進行注解,這是springboot注解式的listener書寫方式。

在servlet容器啟動成功之后,會調用這個監(jiān)聽器的contextInitialized方法,servlet容器如果一旦銷毀,不能提供服務了,會調用監(jiān)聽器的contextDestroyed方法。換句話說,這個監(jiān)聽器在監(jiān)聽servlet容器的狀態(tài)。

然后你只需要在application主類中打開listener配置就好。

@ServletComponentScan
@SpringBootApplication
public class WebApplication {
}

3、這兩種方式的比較

對于一個對外提供http協(xié)議的web服務,在語義上servlet容器的注冊會顯得清晰一些,但是如果你的spring容器啟動時間過長的話,可能出現servlet初始化完成,并且已經注冊,但是服務不能對外提供訪問的gap time,所以我一般還是使用第一種方式進行注冊。

這種場景是這樣的

可以看到,當servlet注冊成功之后,其實webapplication還沒有啟動完成,這個時候服務是不能正常提供訪問的。

在zk上可以看到,兩次注冊都已經成功了。

總結

以上所述是小編給大家介紹的springboot 注冊服務注冊中心(zk)的兩種方式詳解,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對腳本之家網站的支持!

相關文章

  • Java線程同步實例分析

    Java線程同步實例分析

    這篇文章主要介紹了Java線程同步用法,實例分析了java中線程同步的相關實現技巧與注意事項,具有一定參考借鑒價值,需要的朋友可以參考下
    2015-07-07
  • Java文件(io)編程之文件字符流使用方法詳解

    Java文件(io)編程之文件字符流使用方法詳解

    這篇文章主要為大家詳細介紹了Java文件(io)編程之文件字符流使用方法,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-08-08
  • Java8的EnumMap源碼分析

    Java8的EnumMap源碼分析

    這篇文章主要介紹了Java8的EnumMap源碼分析,EnumMap 是一個用于存儲 key 為枚舉類型的 map,底層使用數組實現(K,V 雙數組),與其他類型 map 不同的是 EnumMap 底層使用雙數組來存儲 key 與 value,key 數組會在構造函數中根據 keyType 進行初始化,需要的朋友可以參考下
    2023-11-11
  • java string類型轉換boolean類型的方法

    java string類型轉換boolean類型的方法

    下面小編就為大家?guī)硪黄猨ava string類型轉換boolean類型的方法。小編覺得挺不錯的,現在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2016-11-11
  • springboot?集成dubbo的步驟詳解

    springboot?集成dubbo的步驟詳解

    這篇文章主要介紹了springboot?簡易集成dubbo的步驟詳解,本文結合示例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2022-04-04
  • IntelliJ IDEA同步代碼時版本沖突而產生出的incoming partial文件問題的解決辦法

    IntelliJ IDEA同步代碼時版本沖突而產生出的incoming partial文件問題的解決辦法

    今天小編就為大家分享一篇關于IntelliJ IDEA同步代碼時版本沖突而產生出的incoming partial文件問題的解決辦法,小編覺得內容挺不錯的,現在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧
    2018-10-10
  • Gson解析空字符串發(fā)生異常的處理方法

    Gson解析空字符串發(fā)生異常的處理方法

    最近在一個項目中遇到一個問題,當面對一些不規(guī)范的json,我們的gson解析經常會拋出各種異常導致app崩潰,通過在網上查找資料,找到了原因,這篇文章給大家介紹了一些可以采取的措施來避免這種情況,有需要的朋友們可以一起來學習學習。
    2016-11-11
  • Java實現在正則表達式中控制大小寫的方法

    Java實現在正則表達式中控制大小寫的方法

    這篇文章主要介紹了Java實現在正則表達式中控制大小寫的方法,結合實例形式分析了java正則表達式中傳遞控制參數的功能與相關操作技巧,需要的朋友可以參考下
    2017-04-04
  • Mybatis接口式編程的原理

    Mybatis接口式編程的原理

    mybatis有兩種實現方式,一種可以通過xml配置文件實現,其二是面向接口編程的實現。本文重點給大家介紹mybatis接口編程的原理,需要的的朋友參考下
    2017-03-03
  • 淺談MyBatis所有的jdbcType類型

    淺談MyBatis所有的jdbcType類型

    在Mybatis中JdbcType類型是一個枚舉類型,它包含了所有的JDBC數據類型,如VARCHAR、INTEGER、DATE等,本文主要介紹了淺談MyBatis所有的jdbcType類型,具有一定的參考價值,感興趣的可以了解一下
    2023-06-06

最新評論