Dubbo配置式开发过程

两种开发方式

配置式开发

创建服务提供者

  • 新建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>
  • Dubbo的Provider的启动
  1. 使用加载 Spring 配置文件方式
public  class Test {
	public  static  void main(String[] args) throws IOException {
		ClassPathXmlApplicationContext	ac	=
		ClassPathXmlApplicationContext("applicationContext-dubbo.xml"); ac.start();
		System.in.read();//阻塞程序,保证 Provider 一直处于发布状态
		}
}
  1. 使用 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>
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值