1. 程式人生 > >Dubbo之——將Dubbo服務打包成Jar包

Dubbo之——將Dubbo服務打包成Jar包

伺服器: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)