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包的配置


<build>
  <finalName>mydubbo-serverfinalName>

  <resources>
    <resource>
      <targetPath>${project.build.directory}/classestargetPath>
      <directory>src/main/resourcesdirectory>
      <filtering>truefiltering>
      <includes>
        <include>**/*.xmlinclude>
        <include>**/*.propertiesinclude>
      includes>
    resource>
    
    <resource>
      <targetPath>${project.build.directory}/classes/META-INF/springtargetPath>
      <directory>src/main/resources/springdirectory>
      <filtering>truefiltering>
      <includes>
        <include>spring-context.xmlinclude>
      includes>
    resource>
  resources>

  <pluginManagement>
    <plugins>
      
      <plugin>
        <groupId>org.eclipse.m2egroupId>
        <artifactId>lifecycle-mappingartifactId>
        <version>1.0.0version>
        <configuration>
          <lifecycleMappingMetadata>
           <pluginExecutions>
              <pluginExecution>
                <pluginExecutionFilter>
                  <groupId>org.apache.maven.pluginsgroupId>
                  <artifactId>maven-dependency-pluginartifactId>
                  <versionRange>[2.0,)versionRange> 
                  <goals>
                    <goal>copy-dependenciesgoal>
                  goals>
                pluginExecutionFilter>
                <action>
                  <ignore />
                action>
              pluginExecution>
            pluginExecutions>
          lifecycleMappingMetadata>
        configuration>
      plugin>
    plugins>
  pluginManagement>
  <plugins>
    
    <plugin>
      <groupId>org.apache.maven.pluginsgroupId>
      <artifactId>maven-jar-pluginartifactId>
      <configuration>
        <classesDirectory>target/classes/classesDirectory>
        <archive>
          <manifest>
            <mainClass>com.alibaba.dubbo.container.MainmainClass>
            
            <useUniqueVersions>falseuseUniqueVersions>
            <addClasspath>trueaddClasspath>
            <classpathPrefix>lib/classpathPrefix>
          manifest>
          <manifestEntries>
            <Class-Path>.Class-Path>
         manifestEntries>
        archive>
      configuration>
    plugin>
    <plugin>
      <groupId>org.apache.maven.pluginsgroupId>
      <artifactId>maven-dependency-pluginartifactId>
      <executions>
        <execution>
          <id>copy-dependenciesid>
          <phase>packagephase>
          <goals>
            <goal>copy-dependenciesgoal>
          goals>
          <configuration>
            <type>jartype>
            <includeTypes>jarincludeTypes>
            <useUniqueVersions>falseuseUniqueVersions>
            <outputDirectory>
              ${project.build.directory}/lib
            outputDirectory>
          configuration>
        execution>
      executions>
    plugin>
  plugins>
build>
用Maven将工程打成jar包后,进入工程的target目录后,将mydubbo-server.jar和lib目录拷贝到指定的目录下,命令行运行java -jar mydubbo-server.jar就可以运行dubbo服务了。(注:lib目录下的所有jar包是mydubbo-server.jar的依赖jar)

你可能感兴趣的:(#,Dubbo(分布式服务框架))