zoukankan      html  css  js  c++  java
  • dubbo的启动方法

    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" />

    一、服务的启动方式:servelet容器过于庞大,占用资源。
    二、main方法在本地用的比较普遍,本地开发调试,单元测试,要掌握,不建议生产使用。
    三、dubbo提供的启动类:建议使用dubbo服务自带的启动类,好处是优雅关机,避免强行关闭导致数据丢失。

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

    [html] view plain copy
     
    1. <build>  
    2.         <finalName>edu-service-user</finalName>  
    3.   
    4.         <resources>  
    5.             <resource>  
    6.                 <targetPath>${project.build.directory}/classes</targetPath>  
    7.                 <directory>src/main/resources</directory>  
    8.                 <filtering>true</filtering>  
    9.                 <includes>  
    10.                     <include>**/*.xml</include>  
    11.                     <include>**/*.properties</include>  
    12.                 </includes>  
    13.             </resource>  
    14.             <!-- 结合com.alibaba.dubbo.container.Main -->  
    15.             <resource>  
    16.                 <targetPath>${project.build.directory}/classes/META-INF/spring</targetPath>  
    17.                 <directory>src/main/resources/spring</directory>  
    18.                 <filtering>true</filtering>  
    19.                 <includes>  
    20.                     <include>spring-context.xml</include>  
    21.                 </includes>  
    22.             </resource>  
    23.         </resources>  
    24.           
    25.         <pluginManagement>  
    26.             <plugins>  
    27.                 <!-- 解决Maven插件在Eclipse内执行了一系列的生命周期引起冲突 -->  
    28.                 <plugin>  
    29.                     <groupId>org.eclipse.m2e</groupId>  
    30.                     <artifactId>lifecycle-mapping</artifactId>  
    31.                     <version>1.0.0</version>  
    32.                     <configuration>  
    33.                         <lifecycleMappingMetadata>  
    34.                             <pluginExecutions>  
    35.                                 <pluginExecution>  
    36.                                     <pluginExecutionFilter>  
    37.                                         <groupId>org.apache.maven.plugins</groupId>  
    38.                                         <artifactId>maven-dependency-plugin</artifactId>  
    39.                                         <versionRange>[2.0,)</versionRange>  
    40.                                         <goals>  
    41.                                             <goal>copy-dependencies</goal>  
    42.                                         </goals>  
    43.                                     </pluginExecutionFilter>  
    44.                                     <action>  
    45.                                         <ignore />  
    46.                                     </action>  
    47.                                 </pluginExecution>  
    48.                             </pluginExecutions>  
    49.                         </lifecycleMappingMetadata>  
    50.                     </configuration>  
    51.                 </plugin>  
    52.             </plugins>  
    53.         </pluginManagement>  
    54.         <plugins>  
    55.             <!-- 打包jar文件时,配置manifest文件,加入lib包的jar依赖 -->  
    56.             <plugin>  
    57.                 <groupId>org.apache.maven.plugins</groupId>  
    58.                 <artifactId>maven-jar-plugin</artifactId>  
    59.                 <configuration>  
    60.                     <classesDirectory>target/classes/</classesDirectory>  
    61.                     <archive>  
    62.                         <manifest>  
    63.                             <mainClass>com.alibaba.dubbo.container.Main</mainClass>  
    64.                             <!-- 打包时 MANIFEST.MF文件不记录的时间戳版本 -->  
    65.                             <useUniqueVersions>false</useUniqueVersions>  
    66.                             <addClasspath>true</addClasspath>  
    67.                             <classpathPrefix>lib/</classpathPrefix>  
    68.                         </manifest>  
    69.                         <manifestEntries>  
    70.                             <Class-Path>.</Class-Path>  
    71.                         </manifestEntries>  
    72.                     </archive>  
    73.                 </configuration>  
    74.             </plugin>  
    75.             <plugin>  
    76.                 <groupId>org.apache.maven.plugins</groupId>  
    77.                 <artifactId>maven-dependency-plugin</artifactId>  
    78.                 <executions>  
    79.                     <execution>  
    80.                         <id>copy-dependencies</id>  
    81.                         <phase>package</phase>  
    82.                         <goals>  
    83.                             <goal>copy-dependencies</goal>  
    84.                         </goals>  
    85.                         <configuration>  
    86.                             <type>jar</type>  
    87.                             <includeTypes>jar</includeTypes>  
    88.                             <useUniqueVersions>false</useUniqueVersions>  
    89.                             <outputDirectory>  
    90.                                 ${project.build.directory}/lib  
    91.                             </outputDirectory>  
    92.                         </configuration>  
    93.                     </execution>  
    94.                 </executions>  
    95.             </plugin>  
    96.         </plugins>  
    97.   
    98.     </build>  



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

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

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

    [html] view plain copy
     
      1. <build>  
      2.     <finalName>****-service</finalName>  
      3.     <resources>  
      4.         <resource>  
      5.             <targetPath>${project.build.directory}/classes</targetPath>  
      6.             <directory>src/main/resources</directory>  
      7.             <filtering>true</filtering>  
      8.             <includes>  
      9.                 <include>**/*</include>  
      10.             </includes>  
      11.         </resource>  
      12.         <!-- 结合com.alibaba.dubbo.container.Main -->  
      13.         <resource>  
      14.             <targetPath>${project.build.directory}/classes/META-INF/spring</targetPath>  
      15.             <directory>src/main/resources/spring</directory>  
      16.             <filtering>true</filtering>  
      17.             <includes>  
      18.                 <include>spring.xml</include>  
      19.             </includes>  
      20.         </resource>  
      21.     </resources>  
      22.       
      23.     <pluginManagement>  
      24.         <plugins>  
      25.             <!-- 解决Maven插件在Eclipse内执行了一系列的生命周期引起冲突 -->  
      26.             <plugin>  
      27.                 <groupId>org.eclipse.m2e</groupId>  
      28.                 <artifactId>lifecycle-mapping</artifactId>  
      29.                 <version>1.0.0</version>  
      30.                 <configuration>  
      31.                     <lifecycleMappingMetadata>  
      32.                         <pluginExecutions>  
      33.                             <pluginExecution>  
      34.                                 <pluginExecutionFilter>  
      35.                                     <groupId>org.apache.maven.plugins</groupId>  
      36.                                     <artifactId>maven-dependency-plugin</artifactId>  
      37.                                     <versionRange>[2.0,)</versionRange>  
      38.                                     <goals>  
      39.                                         <goal>copy-dependencies</goal>  
      40.                                     </goals>  
      41.                                 </pluginExecutionFilter>  
      42.                                 <action>  
      43.                                     <ignore />  
      44.                                 </action>  
      45.                             </pluginExecution>  
      46.                         </pluginExecutions>  
      47.                     </lifecycleMappingMetadata>  
      48.                 </configuration>  
      49.             </plugin>  
      50.         </plugins>  
      51.     </pluginManagement>  
      52.     <plugins>  
      53.         <plugin>  
      54.             <groupId>org.apache.maven.plugins</groupId>  
      55.             <artifactId>maven-compiler-plugin</artifactId>  
      56.             <version>3.1</version>  
      57.             <configuration>  
      58.                 <source>1.8</source>  
      59.                 <target>1.8</target>  
      60.                 <encoding>UTF-8</encoding>  
      61.                 <compilerArgs>  
      62.                     <arg>-extdirs</arg>  
      63.                     <arg>${project.basedir}/src/main/webapp/WEB-INF/lib</arg>  
      64.                 </compilerArgs>  
      65.             </configuration>  
      66.         </plugin>  
      67.         <plugin>  
      68.             <groupId>org.apache.maven.plugins</groupId>  
      69.             <artifactId>maven-war-plugin</artifactId>  
      70.             <version>2.6</version>  
      71.             <configuration>  
      72.                 <warName>****</warName>  
      73.                 <archive>  
      74.                     <addMavenDescriptor>false</addMavenDescriptor>  
      75.                 </archive>  
      76.             </configuration>  
      77.         </plugin>  
      78.     </plugins>  
      79. </build>  
  • 相关阅读:
    2
    1
    nginx隐藏版本号
    全面对比主流 .NET 报表控件 (转)
    前端的发展和未来趋势
    NPM初学者指南 (转)
    一文解读MySQL事务
    如何高效的学习技术
    重新统一的 .NET平台-.NET 5
    为啥要有微服务?啥是微服务?
  • 原文地址:https://www.cnblogs.com/liuruilongdn/p/7337806.html
Copyright © 2011-2022 走看看