1. 程式人生 > >【dubbo】服務提供者執行的三種方式

【dubbo】服務提供者執行的三種方式

## 參考文章 ##

使用Servlet容器執行(Tomcat、Jetty等) ## 不可取

  • 增加複雜性(埠,管理)
  • 浪費資源(記憶體)

自建Main方法類來執行(Spring容器) ## 不建議

  • dubbo本身提供的高階特性沒用上
  • 自己編寫的啟動類可能會有缺陷

使用Dubbo框架提供的Main方法類來執行(Spring容器) ## 建議使用

  • 框架本身提供(com.alibaba.dubbo.container.Main)
  • 可實現優雅關機
    關機的時候,伺服器有可能還在處理業務,如果直接停止伺服器,有可能造成資料的丟失,優雅關機就是不再接受新的請求,等待一段時間(處理未處理完的請求),再關機。

第一種配置

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
         xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
    <parent>
        <artifactId
>
parent</artifactId> <groupId>com.dubbopay</groupId> <version>1.0-SNAPSHOT</version> <relativePath>../parent/pom.xml</relativePath> </parent> <modelVersion>4.0.0</modelVersion> <artifactId>service-user</artifactId
>
<version>1.0-SNAPSHOT</version> <!--程式碼除錯時,使用tomcat,打成war包--> <!--<packaging>war</packaging>--> <packaging>jar</packaging> <dependencies> </dependencies> <!-- 配置tomcat外掛 --> <!--程式碼除錯時,使用tomcat,打成war包--> <build> <!--<plugins>--> <!--<plugin>--> <!--<groupId>org.apache.tomcat.maven</groupId>--> <!--<artifactId>tomcat7-maven-plugin</artifactId>--> <!--<configuration>--> <!--<path>/</path>--> <!--<port>8081</port>--> <!--</configuration>--> <!--</plugin>--> <!--</plugins>--> <finalName>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> <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> <outputDirectory> ${project.build.directory}/lib </outputDirectory> </configuration> </execution> </executions> </plugin> </plugins> </build> </project>

這裡寫圖片描述

第二種配置

第二種配置將所有檔案打成一個jar包

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
         xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
    <parent>
        <artifactId>parent</artifactId>
        <groupId>com.dubbopay</groupId>
        <version>1.0-SNAPSHOT</version>
        <relativePath>../parent/pom.xml</relativePath>
    </parent>
    <modelVersion>4.0.0</modelVersion>

    <artifactId>service-user</artifactId>
    <version>1.0-SNAPSHOT</version>
    <!--程式碼除錯時,使用tomcat,打成war包-->
    <!--<packaging>war</packaging>-->
    <packaging>jar</packaging>

    <dependencies>

      <!--jar包依賴......-->

    </dependencies>

    <!-- 配置tomcat外掛 -->
    <!--程式碼除錯時,使用tomcat,打成war包-->
    <build>
        <!--<plugins>-->
            <!--<plugin>-->
                <!--<groupId>org.apache.tomcat.maven</groupId>-->
                <!--<artifactId>tomcat7-maven-plugin</artifactId>-->
                <!--<configuration>-->
                    <!--<path>/</path>-->
                    <!--<port>8081</port>-->
                <!--</configuration>-->
            <!--</plugin>-->
        <!--</plugins>-->

        <finalName>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>

        <plugins>
            <plugin>

                <groupId>com.jolira</groupId>
                <artifactId>onejar-maven-plugin</artifactId>
                <version>1.4.4</version>
                <executions>
                    <execution>
                        <configuration>
                            <mainClass>com.alibaba.dubbo.container.Main</mainClass>
                            <attachToBuild>true</attachToBuild>
                            <!-- https://code.google.com/p/onejar-maven-plugin/issues/detail?id=8 -->
                            <!--classifier>onejar</classifier-->
                            <filename>${project.build.finalName}-onejar.${project.packaging}</filename>
                        </configuration>
                        <goals>
                            <goal>one-jar</goal>
                        </goals>
                    </execution>
                </executions>
            </plugin>
        </plugins>

    </build>

</project>

這裡寫圖片描述