接上文,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即可
相关推荐
根据阿里巴巴dubbo框架官网的说明写的dubbo服务端和消费端的简单快速启动案例
此demo简介:包含user-api(提供接口服务),user-core(接口服务实现)、user-web(消费服务端)、user-admin(消费服务端)四个模块,user-web和user-admin调用user-core暴露的服务。 运行:down下来之后,启动...
node 采用 dubbo 协议连接 dubbo 服务端. 基本步骤 java 启动服务端, 在 zookeeper 注册 node 连接 zookeeper, 获取已经注册的服务, 获取需要的服务端的信息 node 发起 dubbo 协议的 tcp 连接, 获取调用结果, 完成 ...
Dubbo 是基于NIO的非阻塞实现并行调用,客户端不需要启动多线程即可完成并行调用多个远程服务,相对多线程开销较小,异步调用会返回一个 Future 对象。 Dubbo 的注册中心可以选择 Zookeeper、Redis、Multicast、...
SpringBoot-Dubbo脚手架项目 构建 Zookeeper + Dubbo + Spring Boot 的...安装 Dubbo 服务端 构建 Zookeeper + Dubbo + Spring Boot 的分布式调用项目 技术讨论 & 如果对项目有任何疑问或者建议,欢迎到我的博客留言!
在 Dubbo 的用户文档中,推荐如果能在服务端多配置就尽量多配置,因为服务提供者比消费者更清楚自己提供的服务特性。 2. Dubbo 中 zookeeper 做注册中心,如果注册中心集群都挂掉,者和订阅者之间还能通信么? ...
dubbo 例子,里面既有 zookeeper 的基本操作例子,也有dubbo的客户端和服务端,如果你有安装 zookeeper 那么就直接配置你自己的 zookeeper 地址,如果没有的话,就启动那个 testzookeeper 里面的 ...
"分布式服务框架dubbox学习总结" Dubbox是阿里巴巴公司开源的一个高性能优秀的分布式...API 甚至 AJAX 服务端等等的开发。事实上,这个 REST 调用也使得 Dubbo 可以对当今特别流行的“微服务”架构提供基础性支持。
这两天准备复习一下java,所以写一个采用dubbo的商场项目练练手,却卡第一个测试上,启动provider服务和Consumer服务,请求接口却始终报zookeeper请求超时错误(dubbo+zookeeper服务端重复调用三次),经过排查,我的...
扫码支付、电脑支付、WAP支付、APP支付服务端 微信 扫码支付(模式一二)、公众号H5支付、WAP支付 银联 电脑支付、WAP支付 SpringMvc-Dubbox-pay版本(废弃不再维护) 开发环境 JDK1.8、Maven、IDEA、SpringBoot...
AIO : Asynchronous IO,即异步非阻塞,采用了 Proactor 模式,特点是先由操作系统完成后才通知服务端程序启动线程去处理,一般适用于连接数较多且连接时间较长的应用。 既然BIO和NIO都是以同步的方式工作的,那么...
配合spring以及用docker启动中间件做Java生态研究,测试(如:redis,ignite,任务,zookeeper,dubbo,kafka,rabbitmq等) 对常见技术的整合,以及前沿新技术的整合(如:kotlin,webflux) 启动说明 如果是不依赖...
Spring-boot-pay支付服务:支付宝,微信,银联详细 代码案例 (支付宝和微信支付测试均需要企业认证,如果没有企业推荐使用 [服务商模式] 申请开通个人商户 也可以测试 ),项目启动前请仔细阅读 注意事项 。...
轻量级restful接口服务端,无需tomcat部署启动。通过RestfulStart启动接口,使用ApiDocRunner可以自动生成接口文档模板,修改了GenericControllerParser源码以支持blade-mvc框架下无法定义参数是否必填属性问题。
1,spring-cloud-alibaba依赖性2.2.0.RELEASE版本dubbo2.7.8与springboot的兼容问题dubbo2.7.8中添加了MetadataService,会出现本地启动多个dubbo20880端口重复注册,导致端口占用 2,集成seata确保服务端和客户端...
循序渐进写RPC1.Rpc-Api模块的构建首先我们分析一下Dubbo的原理,才可以进一步集成RPC。总体流程而言,基于一个公共接口。服务端这一方有具体的实现。启动注册中心,主要有ZK,Nacos,Rureka等。服务端将服务注册到...
* 为了方便大学家习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' ...
2. conntector 与 connector-2 这两个模块并不一样,connector-2 使用了 Dubbo 进行消息转发(实验阶段),而 connector 使用 Feign 进行 HTTP 调用转发消息。启动 connector 就行了。 3. 每个服务都允许运行多个...