Dubbo服务治理篇——你知道如何将Dubbo服务打包成Jar文件吗?这篇文章帮你搞定!!

Dubbo服务治理篇——你知道如何将Dubbo服务打包成Jar文件吗?这篇文章帮你搞定!!

一、Dubbo服务的运行方式

1、使用Servlet容器运行(Tomcat、Jetty等)----不可取 缺点:增加复杂性(端口、管理)

tomcat/jetty等占用端口,dubbo服务也需要端口

浪费资源(内存):单独启动tomcat,jetty占用内存大

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

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

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

3、使用Dubbo框架提供的Main方法类来运行(Spring容器)----建议使用 优点:框架本身提供(com.alibaba.dubbo.container.Main)

可实现优雅关机(ShutdownHook)

注意点:

代码语言:javascript代码运行次数:0运行复制spring-context.xml

官方:

服务容器的加载内容可以扩展,内置了spring, jetty, log4j等加载,可通过Container扩展点进行扩展

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

原理:

服务提供方停止时,先标记为不接收新请求,新请求过来时直接报错,让客户端重试其它机器。然后,检测线程池中的线程是否正在运行,如果有,等待所有线程执行完成,除非超时,则强制关闭。

服务消费方停止时,不再发起新的调用请求,所有新的调用在客户端即报错。然后,检测有没有请求的响应还没有返回,等待响应返回,除非超时,则强制关闭。

二、Maven构建Dubbo服务可执行Jar包的配置代码语言:javascript代码运行次数:0运行复制

mydubbo-server

${project.build.directory}/classes

src/main/resources

true

**/*.xml

**/*.properties

${project.build.directory}/classes/META-INF/spring

src/main/resources/spring

true

spring-context.xml

org.eclipse.m2e

lifecycle-mapping

1.0.0

org.apache.maven.plugins

maven-dependency-plugin

[2.0,)

copy-dependencies

org.apache.maven.plugins

maven-jar-plugin

target/classes/

com.alibaba.dubbo.container.Main

false

true

lib/

.

org.apache.maven.plugins

maven-dependency-plugin

copy-dependencies

package

copy-dependencies

jar

jar

false

${project.build.directory}/lib

用Maven将工程打成jar包后,进入工程的target目录后,将mydubbo-server.jar和lib目录拷贝到指定的目录下,命令行运行

代码语言:javascript代码运行次数:0运行复制java -jar mydubbo-server.jar就可以运行dubbo服务了。(注:lib目录下的所有jar包是mydubbo-server.jar的依赖jar)。

如果想在服务后台运行Jar文件,可以使用如下命令启动Jar文件。

代码语言:javascript代码运行次数:0运行复制nohup java -jar mydubbo-server.jar >> /dev/null &

相关作品

户口本需要保价吗?如果保价保多少合适呢?
beat365官网下载苹果手机

户口本需要保价吗?如果保价保多少合适呢?

📅 07-16 👀 8331
凭色识温泉——温泉的色彩与水质
beat365官网下载苹果手机

凭色识温泉——温泉的色彩与水质

📅 06-27 👀 8907