关闭

dubbo服务启动方式对比

7434人阅读 评论(1) 收藏 举报
分类:

 Dubbo服务的运行方式:

1、使用Servlet容器运行(Tomcat、Jetty等)----不可取 缺点:增加复杂性(端口、管理) 浪费资源(内存)
2、自建Main方法类来运行(Spring容器) ----不建议(本地调试可用) 缺点: Dobbo本身提供的高级特性没用上 自已编写启动类可能会有缺陷
3、使用Dubbo框架提供的Main方法类来运行(Spring容器)----建议使用 优点:框架本身提供(com.alibaba.dubbo.container.Main) 可实现优雅关机(ShutdownHook)
注意点: spring-context.xml <import resource="classpath:spring/spring-xxx.xml" />

以下是dubbo服务的打包及启动配置,打出jar包的服务:

<build>
		<finalName>edu-service-user</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>


五、启动jar包,定位到相应的目录下,执行  java -jar edu-service-user.jar &

修改spring-context.xml文件中对另外两个文件的引用路径:前面加上classpath:spring/spring-mybatis.xml

六、当然了,我们的服务是war包,直接部署在tomcat就ok了。配置如下:

<build>
	<finalName>****-service</finalName>
	<resources>
		<resource>
			<targetPath>${project.build.directory}/classes</targetPath>
			<directory>src/main/resources</directory>
			<filtering>true</filtering>
			<includes>
				<include>**/*</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.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>
		<plugin>
			<groupId>org.apache.maven.plugins</groupId>
			<artifactId>maven-compiler-plugin</artifactId>
			<version>3.1</version>
			<configuration>
				<source>1.8</source>
				<target>1.8</target>
				<encoding>UTF-8</encoding>
				<compilerArgs>
					<arg>-extdirs</arg>
					<arg>${project.basedir}/src/main/webapp/WEB-INF/lib</arg>
				</compilerArgs>
			</configuration>
		</plugin>
		<plugin>
			<groupId>org.apache.maven.plugins</groupId>
			<artifactId>maven-war-plugin</artifactId>
			<version>2.6</version>
			<configuration>
				<warName>****</warName>
				<archive>
					<addMavenDescriptor>false</addMavenDescriptor>
				</archive>
			</configuration>
		</plugin>
	</plugins>
</build>


0
2
查看评论

Dubbo Main启动方式浅析

服务容器是一个standalone的启动程序,因为后台服务不需要Tomcat或JBoss等Web容器的功能,如果硬要用Web容器去加载服务提供方,增加复杂性,也浪费资源。 服务容器只是一个简单的Main方法,并加载一个简单的Spring容器,用于暴露服务。 服务容器的加载内容可以...
  • xiaomin1991222
  • xiaomin1991222
  • 2016-03-10 16:05
  • 21232

【初级教程】—Dubbo的配置及启动

Tomcat+Dubbo安装         1.将tomcat的webapps目录下的所有文件清空,讲Dubbo管理控制台的程序dubbo-admin-2.5.3.war放 到webapps中,并且解压命名为ROOT。     ...
  • hanxintong9
  • hanxintong9
  • 2016-07-31 15:16
  • 8520

Dubbo Main启动方式浅析

服务容器是一个standalone的启动程序,因为后台服务不需要Tomcat或JBoss等Web容器的功能,如果硬要用Web容器去加载服务提供方,增加复杂性,也浪费资源。  服务容器只是一个简单的Main方法,并加载一个简单的Spring容器,用于暴露服务。  服务容器的加载...
  • CloasGao
  • CloasGao
  • 2017-05-04 14:17
  • 1056

Dubbo——服务端启动过程分析

服务端启动过程分析 1  触发服务注册过程 服务端的启动过程中,对服务暴露由ServiceBean类开始处理逻辑,该类继承了标签对应的配置类ServiceConfig,还实现了一系列Spring接口用于参与Spring容器的启动以及bean的创建过程中去。ServiceBean类实现...
  • meilong_whpu
  • meilong_whpu
  • 2017-05-15 16:16
  • 1390

Dubbo之旅--启动解析

通过之前系列文章我们已经对Dubbo已经有了一个整体的印象,接下来我们从其他角度来进一步了解它.Dubbo通过Spring的加载而启动,本文分析了通过注解方式加载的过程.      1.Schema扩展      ...
  • jnqqls
  • jnqqls
  • 2015-04-29 21:17
  • 10787

Dubbo Main启动方式配置

服务容器是一个standalone的启动程序,因为后台服务不需要Tomcat或JBoss等Web容器的功能,如果硬要用Web容器去加载服务提供方,增加复杂性,也浪费资源。  服务容器只是一个简单的Main方法,并加载一个简单的Spring容器,用于暴露服务。  服务容器的加载内容...
  • lr131425
  • lr131425
  • 2017-03-07 17:02
  • 4077

Dubbo应用启动与停止脚本,超详细解析

本周刚好研究了一下dubbo的启动脚本,所以在官网的启动脚本和公司内部的启动脚本做了一个整理,弄了一份比较通过的Dubbo应用启动和停止脚本。 下面的脚本只应用于配置分离的应用,什么叫做配置分离呢?就是使用maven打包时,借助assemble插件,打一个tar.gz的压缩包。里面有三个目...
  • Evankaka
  • Evankaka
  • 2017-03-12 15:01
  • 6457

【dubbo】dubbo服务注册三种方式

dubbo官方提供了三种注册方式。分别是: 1、利用main方法进行服务注册 2、利用tomcat容器 3、利用dubbo官方提提供的com.alibaba.dubbo.container.Main方法 三种方式各有利弊。这篇文章以一个简单的例子来简单的介绍一下这三种注册方式,在看这篇博客前,相信已...
  • wangyy130
  • wangyy130
  • 2016-06-23 11:25
  • 10637

zookeeper安装和使用 windows环境+dubbo管理控制台的安装 【以及】 tomcat启动配置

综合:zookeeper+dubbo+tomcat【windows环境】 转自:zookeeper安装和使用 windows环境http://blog.csdn.net/tlk20071/article/details/52028945 dubbo管理控制台的安装 【以及】 tomcat启动配置ht...
  • zh123456zh789
  • zh123456zh789
  • 2017-03-15 12:18
  • 1509

DUBBO启动为啥不用web容器启动

dubbo服务容器是一个standalone的启动程序,因为后台服务不需要Tomcat或JBoss等Web容器的功能,如果硬要用Web容器去加载服务提供方,增加复杂性,也浪费资源。 服务容器只是一个简单的Main方法,并加载一个简单的Spring容器,用于暴露服务。 服务容器的加...
  • DCX903170332
  • DCX903170332
  • 2015-10-28 17:17
  • 6072
    个人资料
    • 访问:72122次
    • 积分:1861
    • 等级:
    • 排名:千里之外
    • 原创:124篇
    • 转载:30篇
    • 译文:0篇
    • 评论:6条