Dubbo之——将Dubbo服务打包成Jar包
来源:互联网 发布:vb高级教学视频教程 编辑:程序博客网 时间:2024/06/03 08:15
转载请注明出处:http://blog.csdn.net/l1028386804/article/details/70500018
服务器:192.168.1.121(mydubbo-server)
一、Dubbo服务的运行方式
1、使用Servlet容器运行(Tomcat、Jetty等)----不可取 缺点:增加复杂性(端口、管理)
tomcat/jetty等占用端口,dubbo服务也需要端口
浪费资源(内存):单独启动tomcat,jetty占用内存大
2、自建Main方法类来运行(spring容器) ----不建议(本地调试可用)
缺点: Dobbo本身提供的高级特性没用上
自已编写启动类可能会有缺陷
3、使用Dubbo框架提供的Main方法类来运行(Spring容器)----建议使用 优点:框架本身提供(com.alibaba.dubbo.container.Main)
可实现优雅关机(ShutdownHook)
注意点
spring-context.xml<import resource="classpath:spring/xxx.xml" />官方:服务容器的加载内容可以扩展,内置了spring, jetty, log4j等加载,可通过Container扩展点进行扩展
Dubbo是通过JDK的ShutdownHook来完成优雅停机的,所以如果用户使用"kill -9 PID"等强制关闭指令,是不会执行优雅停机的,只有通过"kill PID"时,才会执行。
原理:
服务提供方停止时,先标记为不接收新请求,新请求过来时直接报错,让客户端重试其它机器。 然后,检测线程池中的线程是否正在运行,如果有,等待所有线程执行完成,除非超时,则强制关闭。
服务消费方停止时,不再发起新的调用请求,所有新的调用在客户端即报错。然后,检测有没有请求的响应还没有返回,等待响应返回,除非超时,则强制关闭。
二、Maven构建Dubbo服务可执行Jar包的配置
<!--MAVEN打包duboo可执行jar begin --><build><finalName>mydubbo-server</finalName><resources><resource><targetPath>${project.build.directory}/classes</targetPath><directory>src/main/resources</directory><filtering>true</filtering><includes><include>**/*.xml</include><include>**/*.properties</include></includes></resource><!-- 结合com.alibaba.dubbo.container.Main --><resource><targetPath>${project.build.directory}/classes/META-INF/spring</targetPath><directory>src/main/resources/spring</directory><filtering>true</filtering><includes><include>spring-context.xml</include></includes></resource></resources><pluginManagement><plugins><!-- 解决Maven插件在Eclipse内执行了一系列的生命周期引起冲突 --><plugin><groupId>org.eclipse.m2e</groupId><artifactId>lifecycle-mapping</artifactId><version>1.0.0</version><configuration><lifecycleMappingMetadata><pluginExecutions><pluginExecution><pluginExecutionFilter><groupId>org.apache.maven.plugins</groupId><artifactId>maven-dependency-plugin</artifactId><versionRange>[2.0,)</versionRange> <goals><goal>copy-dependencies</goal></goals></pluginExecutionFilter><action><ignore /></action></pluginExecution></pluginExecutions></lifecycleMappingMetadata></configuration></plugin></plugins></pluginManagement><plugins><!-- 打包jar文件时,配置manifest文件,加入lib包的jar依赖 --><plugin><groupId>org.apache.maven.plugins</groupId><artifactId>maven-jar-plugin</artifactId><configuration><classesDirectory>target/classes/</classesDirectory><archive><manifest><mainClass>com.alibaba.dubbo.container.Main</mainClass><!-- 打包时 MANIFEST.MF文件不记录的时间戳版本 --><useUniqueVersions>false</useUniqueVersions><addClasspath>true</addClasspath><classpathPrefix>lib/</classpathPrefix></manifest><manifestEntries><Class-Path>.</Class-Path></manifestEntries></archive></configuration></plugin><plugin><groupId>org.apache.maven.plugins</groupId><artifactId>maven-dependency-plugin</artifactId><executions><execution><id>copy-dependencies</id><phase>package</phase><goals><goal>copy-dependencies</goal></goals><configuration><type>jar</type><includeTypes>jar</includeTypes><useUniqueVersions>false</useUniqueVersions><outputDirectory>${project.build.directory}/lib</outputDirectory></configuration></execution></executions></plugin></plugins></build><!--MAVEN打包duboo可执行jar end -->用Maven将工程打成jar包后,进入工程的target目录后,将mydubbo-server.jar和lib目录拷贝到指定的目录下,命令行运行java -jar mydubbo-server.jar就可以运行dubbo服务了。(注:lib目录下的所有jar包是mydubbo-server.jar的依赖jar)
3 0
- Dubbo之——将Dubbo服务打包成Jar包
- Dubbo系列(十三)Dubbo之将Dubbo服务打包成Jar包
- 将dubbo provider打包成jar包
- 通过Maven将一个dubbo服务打包成可执行的jar包,并向注册中心注册服务
- 可执行jar(dubbo)打包成window服务
- maven打包dubbo服务依赖jar包缺失问题
- Dubbo之——Dubbo服务集群
- Dubbo之——Dubbo服务集群
- Dubbo之使用Maven构建服务的可执行jar包
- 使用maven构建dubbo服务jar包
- idea 创建dubbo服务 jar包形式
- dubbo服务需要的jar包
- Dubbo之——Shell脚本维护Dubbo服务
- Dubbo之——Shell脚本维护Dubbo服务
- maven 导出jar包以及导出dubbo服务jar包
- dubbo-monitor jar包
- Dubbo之——服务只注册
- 分布式架构学习之:005--构建Dubbo服务的可执行jar包
- MyBatis概述
- 类型萃取
- Servlet(17)会话技术Session+Cookie及区别
- apache commons collections CollectionUtils工具类简单使用
- 拉格朗日乘数法(等式约束和不等式约束)及KKT条件
- Dubbo之——将Dubbo服务打包成Jar包
- 背包问题
- mac跑opencv的kcf追踪
- 简单介绍 DOCTYPE
- el jstl使用
- 【python学习笔记】4:精度控制/文件读/split()方法
- LeetCode-118、119. Pascal's Triangle (JAVA)杨辉三角
- 41-连接异常(服务器崩溃后重启)
- android 混淆文件proguard.cfg详解