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包的服务:

  1. <build>
  2. <finalName>edu-service-user</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>**/*.xml</include>
  10. <include>**/*.properties</include>
  11. </includes>
  12. </resource>
  13. <!-- 结合com.alibaba.dubbo.container.Main -->
  14. <resource>
  15. <targetPath>${project.build.directory}/classes/META-INF/spring</targetPath>
  16. <directory>src/main/resources/spring</directory>
  17. <filtering>true</filtering>
  18. <includes>
  19. <include>spring-context.xml</include>
  20. </includes>
  21. </resource>
  22. </resources>
  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. <!-- 打包jar文件时,配置manifest文件,加入lib包的jar依赖 -->
  54. <plugin>
  55. <groupId>org.apache.maven.plugins</groupId>
  56. <artifactId>maven-jar-plugin</artifactId>
  57. <configuration>
  58. <classesDirectory>target/classes/</classesDirectory>
  59. <archive>
  60. <manifest>
  61. <mainClass>com.alibaba.dubbo.container.Main</mainClass>
  62. <!-- 打包时 MANIFEST.MF文件不记录的时间戳版本 -->
  63. <useUniqueVersions>false</useUniqueVersions>
  64. <addClasspath>true</addClasspath>
  65. <classpathPrefix>lib/</classpathPrefix>
  66. </manifest>
  67. <manifestEntries>
  68. <Class-Path>.</Class-Path>
  69. </manifestEntries>
  70. </archive>
  71. </configuration>
  72. </plugin>
  73. <plugin>
  74. <groupId>org.apache.maven.plugins</groupId>
  75. <artifactId>maven-dependency-plugin</artifactId>
  76. <executions>
  77. <execution>
  78. <id>copy-dependencies</id>
  79. <phase>package</phase>
  80. <goals>
  81. <goal>copy-dependencies</goal>
  82. </goals>
  83. <configuration>
  84. <type>jar</type>
  85. <includeTypes>jar</includeTypes>
  86. <useUniqueVersions>false</useUniqueVersions>
  87. <outputDirectory>
  88. ${project.build.directory}/lib
  89. </outputDirectory>
  90. </configuration>
  91. </execution>
  92. </executions>
  93. </plugin>
  94. </plugins>
  95. </build>

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

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

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

    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. <pluginManagement>
    23. <plugins>
    24. <!-- 解决Maven插件在Eclipse内执行了一系列的生命周期引起冲突 -->
    25. <plugin>
    26. <groupId>org.eclipse.m2e</groupId>
    27. <artifactId>lifecycle-mapping</artifactId>
    28. <version>1.0.0</version>
    29. <configuration>
    30. <lifecycleMappingMetadata>
    31. <pluginExecutions>
    32. <pluginExecution>
    33. <pluginExecutionFilter>
    34. <groupId>org.apache.maven.plugins</groupId>
    35. <artifactId>maven-dependency-plugin</artifactId>
    36. <versionRange>[2.0,)</versionRange>
    37. <goals>
    38. <goal>copy-dependencies</goal>
    39. </goals>
    40. </pluginExecutionFilter>
    41. <action>
    42. <ignore />
    43. </action>
    44. </pluginExecution>
    45. </pluginExecutions>
    46. </lifecycleMappingMetadata>
    47. </configuration>
    48. </plugin>
    49. </plugins>
    50. </pluginManagement>
    51. <plugins>
    52. <plugin>
    53. <groupId>org.apache.maven.plugins</groupId>
    54. <artifactId>maven-compiler-plugin</artifactId>
    55. <version>3.1</version>
    56. <configuration>
    57. <source>1.8</source>
    58. <target>1.8</target>
    59. <encoding>UTF-8</encoding>
    60. <compilerArgs>
    61. <arg>-extdirs</arg>
    62. <arg>${project.basedir}/src/main/webapp/WEB-INF/lib</arg>
    63. </compilerArgs>
    64. </configuration>
    65. </plugin>
    66. <plugin>
    67. <groupId>org.apache.maven.plugins</groupId>
    68. <artifactId>maven-war-plugin</artifactId>
    69. <version>2.6</version>
    70. <configuration>
    71. <warName>****</warName>
    72. <archive>
    73. <addMavenDescriptor>false</addMavenDescriptor>
    74. </archive>
    75. </configuration>
    76. </plugin>
    77. </plugins>
    78. </build>

dubbo的启动方法的更多相关文章

  1. dubbo服务启动的方式

    dubbo服务启动的方式: 1.dubbo自带的脚本, 2.直接用main方法启动dubbo的spring容器,参见dubbo-test里的各个例子 3.dubbo的spring boot start ...

  2. angular2系列教程(十)两种启动方法、两个路由服务、引用类型和单例模式的妙用

    今天我们要讲的是ng2的路由系统. 例子

  3. [DUBBO]Dubbo控制台查看方法

    1.dubbo控制台安装方法网上较多,例如转载http://dtbuluo.com/blog/archives/37 2.dubbo控制台查看 由于我们组是开发安装的dubbo.zookeeper等等 ...

  4. [转]❲阮一峰❳Linux 守护进程的启动方法

    ❲阮一峰❳Linux 守护进程的启动方法 "守护进程"(daemon)就是一直在后台运行的进程(daemon). 本文介绍如何将一个 Web 应用,启动为守护进程. 一.问题的由来 ...

  5. Linux下memcached安装和启动方法

    Linux下memcached安装和启动方法 1. 首先下载memcached 和 libevent 包. Memcached用到了libevent这个库用于Socket的处理.下面是下载的两个包文件 ...

  6. 免安装版Tomcat6.0启动方法

    免安装版Tomcat6.0启动方法 1.下载Tomcat Zip压缩包,解压. 2.修改startup.bat文件: 在第一行前面加入如下两行 SET JAVA_HOME=JDK目录 SET CATA ...

  7. Service的两种启动方法

    刚才看到一个ppt,介绍service的两种启动方法以及两者之间的区别. startService 和 bindService startService被形容为我行我素,而bindService被形容 ...

  8. viewController启动方法分析

    viewController启动方法分析 转载:http://blog.csdn.net/dizzthxl/article/details/14170047 首先理清楚一个概念: 创建一个类和实例化一 ...

  9. xWorks下的硬盘启动方法

    在VxWorks下进行开发调试,在目标机上加载VxWorks映像很重要,在目标机上加载VxWorks映像,最重要的是三个步骤: 第一步,修改config.h文件,在config.h文件里包括硬盘驱动. ...

随机推荐

  1. git用ssh方式下载和提交代码

    之前git上传下载代码都是用的http方式,但是今天遇到个大文件上传的时候,http方式上传超出大小限制了413 request entity too large,所以改成了用ssh方式上传,简单记录 ...

  2. SQL注入--盲注及报错注入

    盲注查询 盲注其实就是没有回显,不能直观地得到结果来调整注入数据,只能通过其他方式来得到是否注入成功,主要是利用了一些数据库内置函数来达到的 布尔盲注 布尔很明显Ture跟Fales,也就是说它只会根 ...

  3. POJ 1734 无向图最小环/有向图最小环

    给定一张图,求图中一个至少包含三个点的环,环上的点不重复,并且环上的边的长度之和最小. 点数不超过100个 输出方案 无向图: /*Huyyt*/ #include<bits/stdc++.h& ...

  4. kafka常见命令

    基础命令 查看已有topic 进入kafka解压目录:/home/zallds/kafka_2.10-0.10.2.1 执行如下命令,就会列出所有topic [zallds@PUBLIC-26 bin ...

  5. oracle的监听控制

    来自网络: listener control 监听控制 因为你在键入 lsnrctl 回车之后,就进入到监听控制界面. 在启动.关闭或者重启oracle监听器之前确保使用lsnrctl status命 ...

  6. constant read 和 current read

    来自网络,并且在本机实验完成: onsistent read :我的理解,就是通过scn来读取.  读取的过程中要保证 scn是一致的.举个例子,一个SELECT 语句在SCN=100的时刻开始读取一 ...

  7. UVA - 10829 L-Gap Substrings (后缀自动机+线段树启发式合并)

    题意:统计一段字符串中形如UVU的子串个数(其中V的长度固定为g). 问题等价于求满足$g+1\leqslant |j-i|\leqslant g+LCP(i,j)$的后缀(i,j)的对数,即$\su ...

  8. 【洛谷P4309】最长上升子序列

    题目大意:给定一个序列,初始为空.现在我们将 1 到 N 的数字插入到序列中,每次将一个数字插入到一个特定的位置.每插入一个数字,我们都想知道此时最长上升子序列长度是多少? 题解:学会了 rope 操 ...

  9. OSM全球地图MBTiles,非postgresql方式。

    介绍: https://www.cnblogs.com/i-gps/p/3919475.html 下载和使用: https://openmaptiles.org/ OSM pbf转换: https:/ ...

  10. 关于深度学习之TensorFlow简单实例

    1.对TensorFlow的基本操作 import tensorflow as tf import os os.environ[" a=tf.constant(2) b=tf.constan ...