服务器之家:专注于服务器技术及软件下载分享
分类导航

PHP教程|ASP.NET教程|JAVA教程|ASP教程|编程技术|正则表达式|C/C++|IOS|C#|Swift|Android|JavaScript|易语言|

服务器之家 - 编程语言 - JAVA教程 - springboot 注册服务注册中心(zk)的两种方式详解

springboot 注册服务注册中心(zk)的两种方式详解

2021-03-17 13:49扎心了老铁 JAVA教程

本文通过一个demo讲述一下这两种注册方式,使用的是传统的向zk注册的方案。对springboot 注册zk的相关知识感兴趣的朋友一起看看吧

在使用springboot进行开发的过程中,我们经常需要处理这样的场景:在服务启动的时候,需要向服务注册中心(例如zk)注册服务状态,以便当服务状态改变的时候,可以故障摘除和负载均衡。

我遇到过两种注册的途径:

1、在spring的webapplication启动完成后,直接进行注册;

2、在servlet容器启动完成后,通过listener进行注册。

本文通过一个demo讲述一下这两种注册方式,使用的是传统的向zk注册的方案。

1、spring webapplication启动完成后注册

先上代码看一下

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
@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的方式进行注册

照样先上代码

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
@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容器启动成功之后,会调用这个监听器的contextinitialized方法,servlet容器如果一旦销毁,不能提供服务了,会调用监听器的contextdestroyed方法。换句话说,这个监听器在监听servlet容器的状态。

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

?
1
2
3
4
@servletcomponentscan
@springbootapplication
public class webapplication {
}

3、这两种方式的比较

对于一个对外提供http协议的web服务,在语义上servlet容器的注册会显得清晰一些,但是如果你的spring容器启动时间过长的话,可能出现servlet初始化完成,并且已经注册,但是服务不能对外提供访问的gap time,所以我一般还是使用第一种方式进行注册。

这种场景是这样的

springboot 注册服务注册中心(zk)的两种方式详解

可以看到,当servlet注册成功之后,其实webapplication还没有启动完成,这个时候服务是不能正常提供访问的。

springboot 注册服务注册中心(zk)的两种方式详解

在zk上可以看到,两次注册都已经成功了。

总结

以上所述是小编给大家介绍的springboot 注册服务注册中心(zk)的两种方式详解,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对服务器之家网站的支持!

原文链接:http://www.cnblogs.com/kangoroo/p/8250857.html?utm_source=tuicool&utm_medium=referral

延伸 · 阅读

精彩推荐
  • JAVA教程java的jdbc简单封装方法

    java的jdbc简单封装方法

    本篇文章是对java的jdbc简单封装方法进行了详细的分析介绍,需要的朋友参考下 ...

    internet20132732019-12-29
  • JAVA教程Spark调度架构原理详解

    Spark调度架构原理详解

    这篇文章主要介绍了Spark 调度架构原理详解,具有一定借鉴价值,需要的朋友可以参考下。...

    土肥圆的猿4692021-03-12
  • JAVA教程浅谈Java中replace与replaceAll区别

    浅谈Java中replace与replaceAll区别

    这篇文章主要介绍了Java中replace与replaceAll区别,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随...

    童梦国度5752019-06-21
  • JAVA教程Spring Boot 快速入门指南

    Spring Boot 快速入门指南

    Spring 框架是非常著名的 Java 开源框架,历经十多年的发展,整个生态系统已经非常完善甚至是繁杂,Spring Boot 正是为了解决这个问题而开发的,为 Spring 平...

    Java之家5212020-08-29
  • JAVA教程java基于netty NIO的简单聊天室的实现

    java基于netty NIO的简单聊天室的实现

    这篇文章主要介绍了java基于netty NIO的简单聊天室的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友...

    Alexwym1402020-07-18
  • JAVA教程Springboot实现阿里云通信短信服务有关短信验证码的发送功能

    Springboot实现阿里云通信短信服务有关短信验证码的发送功能

    短信验证码是通过发送验证码到手机的一种有效的验证码系统。主要用于验证用户手机的合法性及敏感操作的身份验证。下面通过本文大家分享Springboot实现...

    喝酒不骑马2322020-12-17
  • JAVA教程全面解析Java中的HashMap类

    全面解析Java中的HashMap类

    HashMap类为Java提供了键值对应的map类型,本文将从源码角度全面解析Java中的HashMap类,同时包括其各种常用操作方法等,欢迎参考与借鉴 ...

    pastqing1322020-05-01
  • JAVA教程java中关于文本文件的读写方法实例总结

    java中关于文本文件的读写方法实例总结

    这篇文章主要介绍了java中关于文本文件的读写方法,实例总结了Java针对文本文件读写的几种常用方法,并对比了各个方法的优劣及特点,具有一定参考借鉴价...

    生活真美好3842020-01-15