两种开发方式
配置式开发
创建服务提供者
新建Maven项目,命名为 dubbo-provider 添加dubbo依赖和zkClient依赖(因为 Dubbo 需要在 Zookeeper 中进行注册,需要上传数据给 Zookeeper,所以需要客户端功能,需要下载 zkClient) 新建实体类,Service 接口和实现类(实体类要求实现 Serializable 接口) 新建 Spring 配置文件(约束头信息可在官方文档中查找,注意绑定 xsd约束文件,要求该文件目录不能有中文)
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans" xmlns:dubbo="http://code.alibabatech.com/schema/dubbo"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" 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-provider"></dubbo:application>
<!--配置注册中心-->
<dubbo:registry address="zookeeper://192.168.76.20:2181"></dubbo:registry>
<!--配置协议-->
<dubbo:protocol name="dubbo" port="20880"></dubbo:protocol>
<!--暴露服务接口-->
<dubbo:service interface="com.bjsxt.service.IStarService" ref="starServiceImpl"></dubbo:service>
<!--注册服务 bean-->
<bean id="starServiceImpl" class="com.bjsxt.service.impl.StarServiceImpl"></bean>
</beans>
使用加载 Spring 配置文件方式
public class Test {
public static void main(String[] args) throws IOException {
ClassPathXmlApplicationContext ac =
ClassPathXmlApplicationContext("applicationContext-dubbo.xml"); ac.start();
System.in.read();//阻塞程序,保证 Provider 一直处于发布状态
}
}
使用 Dubbo 的 Main 类,推荐此方式 注意:
此方式要求:Spring 配置文件路径 classpath:/META-INF/spring/*.xml Main 的包不要导入错误
public class TestDubbo {
public static void main(String[] args) {
Main.main(args);
}
}
创建服务消费者
创建 Consumer 项目,调用服务接口 新建 Maven Project, 命名为 dubbo-consumer 配置 pom.xml,此处和 provider 项目的 pom.xml 配置内容相同 把 dubbo-provider 的 pojo 包和 service 包复制过来. 编写 service 接口和实现类
在 service 实现类中通过@autowired 注入服务提供方对象 配置 spring 配置文件
<!--配置应用名称-->
<dubbo:application name="dubbo-consumer"></dubbo:application>
<!--配置注册中心-->
<dubbo:registry address="zookeeper://192.168.76.20:2181"></dubbo:registry>
<!--声明调用的服务接口-->
<dubbo:reference interface="com.bjsxt.service.IStarService" id="starService"></dubbo:reference>
注解式开发
代码同配置式,只需要在服务提供方实现类上添加@Service(注意该注解为 dubbo 的注解) 服务提供方的 Spring 配置文件内容如下(约束头信息可在官方文档 User Guide 中查找)
<!--配置应用名称-->
<dubbo:application name="dubbo-provider"></dubbo:application>
<!--配置注册中心-->
<dubbo:registry address="zookeeper://192.168.76.20:2181"></dubbo:registry>
<!--配置协议-->
<dubbo:protocol name="dubbo" port="20880"></dubbo:protocol>
<!--扫描 dubbo 注解-->
<dubbo:annotation package="com.bjsxt.service.impl"></dubbo:annotation>
在服务消费方调用服务提供方的属性上添加注解@Reference 表示获取服务接口对象 服务消费方的 Spring 配置文件内容如下(约束头信息可在官方文档 User Guide 中查找)
<!--配置应用名称-->
<dubbo:application name="dubbo-consumer"></dubbo:application>
<!--配置注册中心-->
<dubbo:registry address="zookeeper://192.168.76.20:2181"></dubbo:registry>
<!--扫描 dubbo 注解-->
<dubbo:annotation package="com.bjsxt.service.impl"></dubbo:annotation>
<!--注册服务 bean-->
<bean id="starConsumerServiceImpl" class="com.bjsxt.service.impl.StarConsumerServiceImpl"></bean>