天天看点

学习dubbo(五):使用maven构建dubbo服务的可执行的jar

Dubbo服务的运行方式

 1、使用Servlet容器运行(Tomcat) ----- 不可取

 缺点:增加复杂性(端口、管理)

     浪费资源(内存)

 2、自建Main方法类来运行(Spring容器) -----不建议(本地调试可用)

 缺点:Dubbo本身提供的高级特性没用上

     自己编写启动类可能会有缺陷

 3、使用Dubbo框架提供的Main方法类来运行(Spring容器) -----建议使用

 优点:框架本身提供(com.alibaba.dubbo.container.Main)

     可实现优雅关机(ShutdownHook) 

优雅关机

1、简介

Dubbo是通过JDK的ShutdownHook来完成优雅停机的,所以如果用户使用"kill -9 PID"等强制关闭指令,是不会执行优雅停机的,只有通过"kill PID"时,才会执行。

原理:

服务提供方

停止时,先标记为不接收新请求,新请求过来时直接报错,让客户端重试其它机器。

然后,检测线程池中的线程是否正在运行,如果有,等待所有线程执行完成,除非超时,则强制关闭。

服务消费方

停止时,不再发起新的调用请求,所有新的调用在客户端即报错。

然后,检测有没有请求的响应还没有返回,等待响应返回,除非超时,则强制关闭。

设置优雅停机超时时间,缺省超时时间是10秒:(超时则强制关闭)

如果ShutdownHook不能生效,可以自行调用:

  1、自动加载META-INF/spring目录下的所有Spring配置。

  2、配置:(配在java命令-D参数或者dubbo.properties中)

dubbo.spring.config=classpath*:META-INF/spring/*.xml ----配置spring配置加载位置

2、pom.xml中build

注意:

  spring-context.xml中:

这里构建的jar所引用的其它jar在与此jar同级的lib文件夹中

文件结构:

学习dubbo(五):使用maven构建dubbo服务的可执行的jar

上面的外部引用jar包放在lib文件夹中,下面我们来介绍一种内置打包的方法:

继续阅读