标签:Dubbo 服务 dubbo demo context provider org 2.6
-
首先把github上的源码下为zip包,这里我们选2.6.0版本。
-
我们准备仿写dubbo-demo/dubbo-demo-provider,这个是服务的提供方。
-
用eclipse开发,新建一个其他->maven项目,右键项目->构建项目路径,把原本为1.5的JRE移除,然后add library,选择jre 系统库,选中工作空间缺省JRE(1.8jre)。
-
额然后添加依赖的时候受阻了,因为没有在eclipse配置好maven,所以依赖下载失败。我们转到idea开发。
-
pom:参考官方"D:\ideaProjects\dubbo-dubbo-2.6.0\dubbo-demo\dubbo-demo-provider"代码。
com.alibaba dubbo 2.6.0 com.101tec zkclient 0.10 org.apache.curator curator-framework 4.0.1 com.alibaba fastjson 1.2.46 log4j log4j 1.2.17 org.slf4j slf4j-api 1.7.25 org.apache.commons commons-lang3 3.4 io.netty netty-all 4.0.35.Final -
项目如下:
-
我们新建一个接口和接口实现类,其中只有一个方法,返回一个字符串而已。
-
然后到"D:\ideaProjects\dubbo-dubbo-2.6.0\dubbo-demo\dubbo-demo-provider\src\main\resources\META-INF\spring\dubbo-demo-provider.xml"把配置文件复制了粘贴到resources下。
<?xml version="1.0" encoding="UTF-8"?><!--提供方的应用名称,用于计算依赖关系--> <dubbo:application name="demo-provider" /> <!--使用zookeeper注册中心暴露服务地址:协议用的是zookeeper;当然还有很多其他注册中心,如redis--> <dubbo:registry address="zookeeper://127.0.0.1:2181" /> <!--使用dubbo协议在20880(自定义)端口暴露服务--> <dubbo:protocol name="dubbo" port="20880" /> <!--注册service实现类--> <bean id="demoProviderService" class="com.haien.service.impl.DemoProviderServiceImpl" /> <!--真正暴露一个接口--> <dubbo:service interface="com.haien.service.DemoProviderService" ref="demoProviderService" />
-
然后我们测试一下如何发布接口:
public class ProviderTest {
public static void main(String[] args) {
//读取配置文件
ClassPathXmlApplicationContext context=new ClassPathXmlApplicationContext(
new String[]{“dubbo-demo-provider.xml”});
//启动
context.start();System.out.println("服务注册成功,端口:20880"); try { //读取任意输入终止程序 System.in.read(); } catch (IOException e) { e.printStackTrace(); } context.close(); }
}
-
控制台:
服务注册成功,端口:20880
-
由于网络原因,可能报错:Zookeeper is not connected yet。重启一下zookeeper再运行程序。
标签:Dubbo,服务,dubbo,demo,context,provider,org,2.6 来源: https://blog.csdn.net/jiachunchun/article/details/104192828
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。