Dubbo和Spring集成Demo
2017-04-24 09:32
453 查看
Zookeeper安装和启动
http://mirrors.hust.edu.cn/apache/zookeeper/下载,我的版本是 3.4.5。解压到 D:\zookeeper-3.4.5
配置
到目录conf 下创建 zoo.cfg 文件,默认就是加载这个文件,文件内容 我直接copy 的sample里面的
zoo.cfg 的内容
# 心跳检查的时间 2秒
tickTime=2000
# 初始化时 连接到服务器端的间隔次数,总时间10*2=20秒
initLimit=10
# ZK Leader 和follower 之间通讯的次数,总时间5*2=10秒
syncLimit=5
# 存储内存中数据库快照的位置,如果不设置参数,更新事务日志将被存储到默认位置。
dataDir=D:\zk\tmp\zookeeper
# 错误日志的存放位置
dataLogDir=D:\zk\logs\zookeeper
# ZK 服务器端的监听端口
clientPort=2181
运行
然后 cd 到bin 目录下 执行zkServer.cmd 就启动成功了。利用jps命令行命令可以验证zookeeper是否启动成功。
Dubbo服务注册
建立WEB项目,引入相应Jar文件。
配置web.xml文件
<?xml version="1.0" encoding="UTF-8"?> <web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://java.sun.com/xml/ns/javaee" xmlns:web="http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd" xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd" id="WebApp_ID" version="3.0"> <display-name>dubbo-service</display-name> <welcome-file-list> <welcome-file>index.html</welcome-file> <welcome-file>index.htm</welcome-file> <welcome-file>index.jsp</welcome-file> <welcome-file>default.html</welcome-file> <welcome-file>default.htm</welcome-file> <welcome-file>default.jsp</welcome-file> </welcome-file-list> <context-param> <param-name>contextConfigLocation</param-name> <param-value> WEB-INF/dubbo-provider.xml </param-value> </context-param> <listener> <listener-class>org.springframework.web.context.ContextLoaderListener</listener-class> </listener> <filter> <filter-name>characterEncodingFilter</filter-name> <filter-class>org.springframework.web.filter.CharacterEncodingFilter</filter-class> <init-param> <param-name>encoding</param-name> <param-value>UTF-8</param-value> </init-param> <init-param> <param-name>forceEncoding</param-name> <param-value>true</param-value> </init-param> </filter> <filter-mapping> <filter-name>characterEncodingFilter</filter-name> <url-pattern>/*</url-pattern> </filter-mapping> </web-app>
写服务类: 接口:
public interface IDemoService { /** * * * @Function: com.test.dubbo.service.IDemoService.sayHello * @Description: * * @param name * @return name string * * @version:v1.0 * @author:cjq * @date:2015-4-30 下午5:45:30 * * Modification History: * Date Author Version Description * ----------------------------------------------------------------- * 2015-4-30 cjq v1.0.0 create */ public String sayHello(String name); }
实现:
public class DemoServiceImpl implements IDemoService { /* * (non-Javadoc) * * @see com.test.dubbo.service.IDemoService#sayHello(java.lang.String) */ public String sayHello(String name) { return "Hello Dubbo,Hello " + name; } }
注册服务: 新建dubbo-provider.xml文件,文件内容为:
<?xml version="1.0" encoding="UTF-8"?> <beans xmlns="http://www.springframework.org/schema/beans" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:dubbo="http://code.alibabatech.com/schema/dubbo" xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd http://code.alibabatech.com/schema/dubbo http://code.alibabatech.com/schema/dubbo/dubbo.xsd"> <!-- 提供方应用信息,用于计算依赖关系 --> <dubbo:application name="dubbo-service" /> <!-- 使用multicast广播注册中心暴露服务地址 --> <!-- <dubbo:registry address="multicast://224.5.6.7:1234" /> --> <!-- 使用zookeeper注册中心暴露服务地址 --> <dubbo:registry address="zookeeper://xxxx:2181" /> <!-- 用dubbo协议在20880端口暴露服务 --> <dubbo:protocol name="dubbo" port="20880" /> <!-- 声明需要暴露的服务接口 --> <dubbo:service interface="com.test.dubbo.service.IDemoService" ref="demoService" /> <!-- 和本地bean一样实现服务 --> <bean id="demoService" class="com.test.dubbo.service.impl.DemoServiceImpl" /> </beans>
部署启动服务:
Dubbo服务调用
新建WEB或者普通JAVA工程,引入Dubbo服务注册项目中的jar文件。 需要导入一个服务接口(从上个程序中导入接口的jar并且导入到此项目中。) 配置web.xml文件(和上工程一样),编写调用配置文件dubbo-consumer.xml文件,内容如下:
<?xml version="1.0" encoding="UTF-8"?> <beans xmlns="http://www.springframework.org/schema/beans" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:dubbo="http://code.alibabatech.com/schema/dubbo" xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd http://code.alibabatech.com/schema/dubbo http://code.alibabatech.com/schema/dubbo/dubbo.xsd"> <!-- 提供方应用信息,用于计算依赖关系 --> <dubbo:application name="dubbo-service-consumer" /> <!-- 使用multicast广播注册中心暴露服务地址 --> <!-- <dubbo:registry address="multicast://224.5.6.7:1234" /> --> <!-- 使用zookeeper注册中心暴露服务地址 --> <dubbo:registry address="zookeeper://xxxx:2181" /> <!-- 声明需要暴露的服务接口 --> <dubbo:reference id="demoService" interface="com.test.dubbo.service.IDemoService"/> </beans>
编写测试代码:
/** * Copyright (C) 2015 * * * @className:com.test.dubbo.consumer.ConsumerTest * @description:TODO * * @version:v1.0.0 * @author:cjq * * Modification History: * Date Author Version Description * ----------------------------------------------------------------- * 2015-4-30 cjq v1.0.0 create * * */ package com.test.dubbo.consumer; import org.springframework.context.support.ClassPathXmlApplicationContext; import com.test.dubbo.service.IDemoService; public class ConsumerTest { public static void main(String[] args) { ClassPathXmlApplicationContext context = new ClassPathXmlApplicationContext( "file:D:/javaworkspace/dubbo-service-consumer/WebContent/WEB-INF/dubbo-consumer.xml"); context.start(); IDemoService demoService = (IDemoService) context.getBean("demoService"); // 获取远程服务代理 String hello = demoService.sayHello("world"); // 执行远程方法 System.out.println(hello); } }
Dubbo服务调用结果
调用测试代码,执行结果为:
Dubbo介绍结尾
如果你在做分布式系统的话,不妨用一下这个技术。
相关文章推荐
- Dubbo和Spring集成Demo
- dubbo+springmvc+mybatis集成demo
- 集成Dubbo服务(Spring)
- Maven+SpringMVC+Dubbo 简单的入门demo配置
- Dubbo+Zookeeper+Spring的demo(本地工程+web工程)
- spring集成dubbo的配置文件
- Maven+SpringMVC+Dubbo 简单的入门demo配置
- 集成Dubbo服务(Spring)
- spring-boot集成dubbo报错UnsatisfiedDependencyException
- Dubbo+Zookeeper+Spring整合入门Demo
- springMvc dubbo zookeeper 集成demo
- Maven+SpringMVC+Dubbo 简单的入门demo配置
- 集成Dubbo服务(Spring)
- Dubbo之——与高版本的Spring集成
- struts-2.1.8.1+jquery-1.3.2+spring-framework-2.5.6集成[登录demo]
- Dubbo+Zookeeper+Spring mvc+Nginx 集群负载均衡 详细demo
- 最简单的cxf restful webservice Demo(包括与spring集成)
- Dubbo:关于与高版本的Spring集成的事情
- Spring 集成 Dubbo
- spring集成dubbo