`

duboo服务端启动

 
阅读更多

接上文,dubbo的服务一般情况下,不需要放入tomcat等容器你启动的,可以直接利用spring的容器就可以了,所以在上文中,我们直接使用spring提供的ClassPathXmlApplicationContext来启动容器,由于容器需要不停机,所以我们用了System.in.read()来阻止服务器停机,dubbo官方也提供了启动方式,这种启动方式在生产环境下使用比较好,之前使用的方式在调试环境下使用非常方便

 

配置如下,在pom文件中新增如下插件

<build>

<finalName>test-provider</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</directory>

<filtering>true</filtering>

<includes>

<include>spring-all.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>

 

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

 

注意一下配置项



 将resources文件夹下所有配置文件拷贝入目标文件的classes文件夹下

将resources文件夹下的spring总控文件拷贝入classes/META-INF/spring中,这是dubbo利用自带的main类启动的默认文件夹

 

由于我们将总控文件拷贝到了classes/META-INF/spring文件夹下,所以在spring总控文件中引入其他spring配置文件的路径得修改一下



 要不然,会找不到其他配置文件的

 

利用maven打成jar包,然后直接用java -jar test-provider.jar启动

这里注意,如果需要关闭的话,在linux环境下,直接用kill pid即可

  • 大小: 49 KB
  • 大小: 27.7 KB
分享到:
评论

相关推荐

    dubbo快速启动案例

    根据阿里巴巴dubbo框架官网的说明写的dubbo服务端和消费端的简单快速启动案例

    springmvc+dubbo demo

    此demo简介:包含user-api(提供接口服务),user-core(接口服务实现)、user-web(消费服务端)、user-admin(消费服务端)四个模块,user-web和user-admin调用user-core暴露的服务。 运行:down下来之后,启动...

    node-connect-dubbo-test:Node.js通过Dubbo协议连接到Java服务器

    node 采用 dubbo 协议连接 dubbo 服务端. 基本步骤 java 启动服务端, 在 zookeeper 注册 node 连接 zookeeper, 获取已经注册的服务, 获取需要的服务端的信息 node 发起 dubbo 协议的 tcp 连接, 获取调用结果, 完成 ...

    Dubbo 30道面试题及答案.docx

    Dubbo 是基于NIO的非阻塞实现并行调用,客户端不需要启动多线程即可完成并行调用多个远程服务,相对多线程开销较小,异步调用会返回一个 Future 对象。 Dubbo 的注册中心可以选择 Zookeeper、Redis、Multicast、...

    SpringBoot-Dubbo:SpringBoot整合Dubbo服务

    SpringBoot-Dubbo脚手架项目 构建 Zookeeper + Dubbo + Spring Boot 的...安装 Dubbo 服务端 构建 Zookeeper + Dubbo + Spring Boot 的分布式调用项目 技术讨论 & 如果对项目有任何疑问或者建议,欢迎到我的博客留言!

    Dubbo 38道面试题及答案.docx

    在 Dubbo 的用户文档中,推荐如果能在服务端多配置就尽量多配置,因为服务提供者比消费者更清楚自己提供的服务特性。 2. Dubbo 中 zookeeper 做注册中心,如果注册中心集群都挂掉,者和订阅者之间还能通信么? ...

    dubbo 例子

    dubbo 例子,里面既有 zookeeper 的基本操作例子,也有dubbo的客户端和服务端,如果你有安装 zookeeper 那么就直接配置你自己的 zookeeper 地址,如果没有的话,就启动那个 testzookeeper 里面的 ...

    分布式服务框架dubbox学习总结

    "分布式服务框架dubbox学习总结" Dubbox是阿里巴巴公司开源的一个高性能优秀的分布式...API 甚至 AJAX 服务端等等的开发。事实上,这个 REST 调用也使得 Dubbo 可以对当今特别流行的“微服务”架构提供基础性支持。

    dubbo中zookeeper请求超时问题:mybatis+spring连接mysql8.0.15的配置

    这两天准备复习一下java,所以写一个采用dubbo的商场项目练练手,却卡第一个测试上,启动provider服务和Consumer服务,请求接口却始终报zookeeper请求超时错误(dubbo+zookeeper服务端重复调用三次),经过排查,我的...

    【支付开发包】spring-boot-pay-master

    扫码支付、电脑支付、WAP支付、APP支付服务端 微信 扫码支付(模式一二)、公众号H5支付、WAP支付 银联 电脑支付、WAP支付 SpringMvc-Dubbox-pay版本(废弃不再维护) 开发环境 JDK1.8、Maven、IDEA、SpringBoot...

    Netty高性能网络应用框架.rar

    AIO : Asynchronous IO,即异步非阻塞,采用了 Proactor 模式,特点是先由操作系统完成后才通知服务端程序启动线程去处理,一般适用于连接数较多且连接时间较长的应用。 既然BIO和NIO都是以同步的方式工作的,那么...

    spring-boot-side::maple_leaf:spring-boot及相关知识练习,Java生态研究学习(spring,redis,ignite,任务,zookeeper,dubbo,mybatis,kafka,rabbitmq,webflux);前沿新技术的探索,webflux,响应式编程,kontlin等

    配合spring以及用docker启动中间件做Java生态研究,测试(如:redis,ignite,任务,zookeeper,dubbo,kafka,rabbitmq等) 对常见技术的整合,以及前沿新技术的整合(如:kotlin,webflux) 启动说明 如果是不依赖...

    基于Spring Boot + LayUI开发的Spring-boot-pay支付项目,支持支付宝,微信,银联详细代码案例

    Spring-boot-pay支付服务:支付宝,微信,银联详细 代码案例 (支付宝和微信支付测试均需要企业认证,如果没有企业推荐使用 [服务商模式] 申请开通个人商户 也可以测试 ),项目启动前请仔细阅读 注意事项 。...

    word源码java-learn_java:学习测试模块

    轻量级restful接口服务端,无需tomcat部署启动。通过RestfulStart启动接口,使用ApiDocRunner可以自动生成接口文档模板,修改了GenericControllerParser源码以支持blade-mvc框架下无法定义参数是否必填属性问题。

    spring-cloud-alibaba-demo

    1,spring-cloud-alibaba依赖性2.2.0.RELEASE版本dubbo2.7.8与springboot的兼容问题dubbo2.7.8中添加了MetadataService,会出现本地启动多个dubbo20880端口重复注册,导致端口占用 2,集成seata确保服务端和客户端...

    RPC-Framework:轻量级RPC实现

    循序渐进写RPC1.Rpc-Api模块的构建首先我们分析一下Dubbo的原理,才可以进一步集成RPC。总体流程而言,基于一个公共接口。服务端这一方有具体的实现。启动注册中心,主要有ZK,Nacos,Rureka等。服务端将服务注册到...

    基于SpringBoot+Shiro+Redis+Jwt+Thymeleaf+MyBatis 开发的后台用户、角色+源代码+文档

    * 为了方便大学家习dubbo的运行机制,本框架将dubbo的provider和customer作了一个整合,将官方demo里的方多应用整合成了一个,即在同一应用内启动消费端和服务端 * 注:如有实际业务需要请将服务端与消费端分离,...

    单点登录源码

    Dubbo | 分布式服务框架 | [http://dubbo.io/](http://dubbo.io/) TBSchedule & elastic-job | 分布式调度框架 | [https://github.com/dangdangdotcom/elastic-job](https://github.com/dangdangdotcom/elastic-job)...

    【尚硅谷】徐靖博 最新电商项目实战(完结)

    z* L6 G' j 162.06 服务端provider的配置1 f6 i# U" Y/ ], Q' I" ] 163.07 dubbo和zookeeper的启动 164.08 dubbo消费端访问' T/ a) \9 w& q 165.09 dubbo和负载均衡; ^9 }$ q2 l9 q 166.10 项目总结介绍. q6 S; C' ...

    基于springcloud+Netty+MQ+mysql的分布式即时聊天系统源码+数据库+项目说明.zip

    2. conntector 与 connector-2 这两个模块并不一样,connector-2 使用了 Dubbo 进行消息转发(实验阶段),而 connector 使用 Feign 进行 HTTP 调用转发消息。启动 connector 就行了。 3. 每个服务都允许运行多个...

Global site tag (gtag.js) - Google Analytics