Dubbo基础编二_使用Maven构建Dubbo服务可执行jar包
2018-01-02 22:27
567 查看
服务器:192.168.1.121(edu-provider-01)
一、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包的配置
// 在package或者install时,如果该项目依赖有其他项目,需要将其他项目install到本地仓库中去
三、可执行Dubbo服务Jar在linux上的操作
1.获取数据库密码密文,使用druid
上传druid-0.2.23.jar包到provider-01服务器192.168.1.121上,使用 java -cp druid-0.2.23.jar com.alibaba.druid.filter.config.ConfigTools root获取加密的密码
[root@provider-01 ~]#
java -cp druid-0.2.23.jar com.alibaba.druid.filter.config.ConfigTools root
bNVOqb7WKLX5Bjnw+LMv92taj25KOxDimXxILPQjw42wgv+1lHzOH8kr97xDwWdhpY67
QuYCS7sWN4W46YbkFA==
[root@provider-01 ~]#
2.打包provider提供者服务jar
3.把edu-service-user.jar与其lib上传到provider-01服务器上
[root@provider-01 home]# mkdir /home/yxq/edu/service
[root@provider-01 home]# mkdir /home/yxq/edu/service/user
4.手动执行jar
启动zookeeper注册中心192.168.1.121
[root@provider-01 user]# ls
edu-service-user.jar lib
[root@provider-01 user]# java -jar edu-service-user.jar
dubbo管理控制台
[root@provider-01 user]# ps -ef | grep edu-service
root 12391 11678 1 06:46 pts/0 00:00:08 java -jar edu-service-user.jar
root 12423 11678 0 06:59 pts/0 00:00:00 grep edu-service
[root@provider-01 user]# kill 12391
手工维护Dubbo服务
java -jar edu-service-xxx.jar &
kill PID
kill -9 PID
build设置:
defaultGoal:默认的目标,必须跟命令行上的参数相同,如:jar:jar,或者与时期parse相同,例如install
directory:指定build target目标的目录,默认为$(basedir}/target,即项目根目录下的target
finalName:指定去掉后缀的工程名字,例如:默认为artifactId−artifactId−{version}
filters:用于定义指定filter属性的位置,例如filter元素赋值filters/filter1.properties,那么这个文件里面就可以定义name=value对,这个name=value对的值就可以在工程pom中通过name引用,默认的filter目录是name引用,默认的filter目录是{basedir}/src/main/fiters/
resources:描述工程中资源的位置
targetPath:指定build资源到哪个目录,默认是base directory
filtering:指定是否将filter文件(即上面说的filters里定义的*.property文件)的变量值在这个resource文件有效,例如上面就指定那些变量值在configuration文件无效。
directory:指定属性文件的目录,build的过程需要找到它,并且将其放到targetPath下,默认的directory是${basedir}/src/main/resources
includes:指定包含文件的patterns,符合样式并且在directory目录下的文件将会包含进project的资源文件。
excludes:指定不包含在内的patterns,如果inclues与excludes有冲突,那么excludes胜利,那些符合冲突的样式的文件是不会包含进来的。
testResources:这个模块包含测试资源元素,其内容定义与resources类似,不同的一点是默认的测试资源路径是${basedir}/src/test/resources,测试资源是不部署的。
总结: 将服务提供者实现由dubbo管理. 将其放置与spring容器中,使用maven构建,使用dubbo提供的main方法作为该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)
注意点
spring-context.xml
<import resource=”classpath:spring/xxx.xml” />
官方:服务容器的加载内容可以扩展,内置了spring, jetty, log4j等加载,可通过Container扩展点进行扩展
Dubbo是通过JDK的ShutdownHook来完成优雅停机的,所以如果用户使用”kill -9 PID”等强制关闭指令,是不会执行优雅停机的,只有通过”kill PID”时,才会执行。
原理:
服务提供方停止时,先标记为不接收新请求,新请求过来时直接报错,让客户端重试其它机器。 然后,检测线程池中的线程是否正在运行,如果有,等待所有线程执行完成,除非超时,则强制关闭。
服务消费方停止时,不再发起新的调用请求,所有新的调用在客户端即报错。然后,检测有没有请求的响应还没有返回,等待响应返回,除非超时,则强制关闭。
二、Maven构建Dubbo服务可执行Jar包的配置
<build> <finalName>service</finalName> // 打包后项目的名称 <resources> // jar包中项目的资源 <resource> <targetPath>${project.build.directory}/classes</targetPath> // 打包后的资源放置的位置 <directory>src/main/resources</directory> // 要打包处置的资源 <filtering>true</filtering> <includes> //包括哪些资源 <include>**/*.xml</include> <include>**/*.properties</include> </includes> </resource> <!-- 17cdf 结合com.alibaba.dubbo.container.Main --> <resource> <targetPath>${project.build.directory}/classes/META-INF/spring</targetPath> // dubbo中,会自动加载META-INF/spring下的*.xml文件 <directory>src/main/resources/spring</directory> <filtering>true</filtering> <includes> <include>spring-context.xml</include> //替代了web.xml中的加载该配置文件的配置 </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> // 将依赖的jar包打包至target下的/lib文件夹下 <addClasspath>true</addClasspath> <classpathPrefix>lib/</classpathPrefix> </manifest> <manifestEntries> <Class-Path>.</Class-Path> </manifestEntries> </archive> </configuration> </plugin> // 此处的作用是,指定该项目的启动所依赖的jar包的位置,在该项目的lib文件夹中 <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>
// 在package或者install时,如果该项目依赖有其他项目,需要将其他项目install到本地仓库中去
三、可执行Dubbo服务Jar在linux上的操作
1.获取数据库密码密文,使用druid
上传druid-0.2.23.jar包到provider-01服务器192.168.1.121上,使用 java -cp druid-0.2.23.jar com.alibaba.druid.filter.config.ConfigTools root获取加密的密码
[root@provider-01 ~]#
java -cp druid-0.2.23.jar com.alibaba.druid.filter.config.ConfigTools root
bNVOqb7WKLX5Bjnw+LMv92taj25KOxDimXxILPQjw42wgv+1lHzOH8kr97xDwWdhpY67
QuYCS7sWN4W46YbkFA==
[root@provider-01 ~]#
2.打包provider提供者服务jar
3.把edu-service-user.jar与其lib上传到provider-01服务器上
[root@provider-01 home]# mkdir /home/yxq/edu/service
[root@provider-01 home]# mkdir /home/yxq/edu/service/user
4.手动执行jar
启动zookeeper注册中心192.168.1.121
[root@provider-01 user]# ls
edu-service-user.jar lib
[root@provider-01 user]# java -jar edu-service-user.jar
dubbo管理控制台
[root@provider-01 user]# ps -ef | grep edu-service
root 12391 11678 1 06:46 pts/0 00:00:08 java -jar edu-service-user.jar
root 12423 11678 0 06:59 pts/0 00:00:00 grep edu-service
[root@provider-01 user]# kill 12391
手工维护Dubbo服务
java -jar edu-service-xxx.jar &
kill PID
kill -9 PID
build设置:
defaultGoal:默认的目标,必须跟命令行上的参数相同,如:jar:jar,或者与时期parse相同,例如install
directory:指定build target目标的目录,默认为$(basedir}/target,即项目根目录下的target
finalName:指定去掉后缀的工程名字,例如:默认为artifactId−artifactId−{version}
filters:用于定义指定filter属性的位置,例如filter元素赋值filters/filter1.properties,那么这个文件里面就可以定义name=value对,这个name=value对的值就可以在工程pom中通过name引用,默认的filter目录是name引用,默认的filter目录是{basedir}/src/main/fiters/
resources:描述工程中资源的位置
<resource> <targetPath>META-INF/plexus</targetPath> <filtering>false</filtering> <directory>${basedir}/src/main/plexus</directory> <includes> <include>configuration.xml</include> </includes> <excludes> <exclude>**/*.properties</exclude> </excludes> </resource>
targetPath:指定build资源到哪个目录,默认是base directory
filtering:指定是否将filter文件(即上面说的filters里定义的*.property文件)的变量值在这个resource文件有效,例如上面就指定那些变量值在configuration文件无效。
directory:指定属性文件的目录,build的过程需要找到它,并且将其放到targetPath下,默认的directory是${basedir}/src/main/resources
includes:指定包含文件的patterns,符合样式并且在directory目录下的文件将会包含进project的资源文件。
excludes:指定不包含在内的patterns,如果inclues与excludes有冲突,那么excludes胜利,那些符合冲突的样式的文件是不会包含进来的。
testResources:这个模块包含测试资源元素,其内容定义与resources类似,不同的一点是默认的测试资源路径是${basedir}/src/test/resources,测试资源是不部署的。
总结: 将服务提供者实现由dubbo管理. 将其放置与spring容器中,使用maven构建,使用dubbo提供的main方法作为该jar包的程序入口,节省系统资源与内存,减小系统复杂性
相关文章推荐
- Dubbo基础篇_04_使用Maven构建Dubbo服务可执行jar包
- 菜鸟的DUBBO进击之路(六):使用maven构建dubbo服务的可执行jar包
- Dubbo之使用Maven构建服务的可执行jar包
- 跟我学习dubbo-使用Maven构建Dubbo服务的可执行jar包(4)
- 使用maven 构建dubbo服务的可执行jar包
- SpringBank 开发日志 使用maven构建dubbo服务的可执行jar包
- 分布式服务框架dubbo-使用Maven构建Dubbo服务的可执行jar包(4)
- 学习dubbo(五):使用maven构建dubbo服务的可执行的jar
- 使用maven构建dubbo服务的可执行jar包
- 跟我学习dubbo-使用Maven构建Dubbo服务的可执行jar包(4)
- Dubbo服务的运行方式(使用maven构建dubbo可执行的jar包)
- 使用Maven构建dubbo服务可执行的jar包--待完善
- 使用maven构建Dubbo服务的可执行的jar包
- Dubbo-使用Maven构建Dubbo服务的可执行jar包
- 使用Maven构建Dubbo服务的可运行jar包 支持优雅关机
- 基于maven构建dubbo服务的可执行jar包
- [置顶] dubbo-3 使用maven构建dubbo可执行jar包
- maven构建dubbo服务的可执行jar包
- 使用maven构建dubbo服务的可执行jar包
- 使用Maven构建dubbo服务可执行的jar包