Dubbo学习— 消费者提供者搭建

Dubbo学习— 消费者提供者搭建

环境条件

  1. linux centos7 阿里云
  2. springboot
  3. dubbo2.6.5 版本
  4. idea

看完本篇博客,学习可以掌握在springboot环境下dubbo的demo搭建
源码地址:https://github.com/zzjmay123/dubbo-zzjmay.git

dubbo-Admin (dubbo控制台)

在搭建dubbo的提供者和消费者的时候,我们先在远程服务器上部署上dubbo控制台,可以实时的查看应用数,提供者,消费者的相关信息
第一步 :到dubbo控制台的源码
https://github.com/apache/incubator-dubbo-ops.git
第二步:修改dubbo-admin文件目录下的application.properties的配置文件
需要替换这里的注册中心地址为自己zk地址
dubbo.registry.address=zookeeper://X.X.X.X:2181
第三步:在远程服务器上部署dubbo-admin应用
因为是springboot应用,所以部署起来比较容易,先进入dubbo-admin下进行打包 mvn clean package
然后在执行 nohup java -jar XXX.jar > /dev/null 2>&1 &
注意:这里一定要用nohup的命令,允许其在后端运行,不然ssh链接断开后,tomcat的进程也随之销毁
成功截图如下:
在这里插入图片描述

dubbo Demo 基于springboot

项目的目录结构如下:
在这里插入图片描述
zzjmay-dubbo-api 是基于dubbo的分包原则抽离出来的一个模块,用于对外暴露的接口层面的API
zzjmay-dubbo-consumer 是一个springboot应用,消费者
zzjmay-dubbo-product 是一个springboot应用,提供者

搭建服务提供者 zzjmay-dubbo-product
第一步 引入dubbo的springboot的包
    <dependency>
		<groupId>com.alibaba.boot</groupId>
		<artifactId>dubbo-spring-boot-starter</artifactId>
		<version>0.2.0</version>
	</dependency>
第二步 配置dubbo的服务端属性
##配置应用名称
dubbo.application.name=zzjmay-dubbo-product
##配置注册中心地址
dubbo.registry.address=zookeeper://X.X.X.X:2181
##配置dubbo的协议名称
dubbo.protocol.name=dubbo
##配置协议端口
dubbo.protocol.port=20880
第三部 暴露提供的服务,用@Service
/**
 * 注意这个@Service 是dubbo下的服务暴露,而不是spring的
 * Created by zzjmay on 2018/12/10.
 */
@Service
public class UserServiceImpl implements UserService {


    @Override
    public List<UserAdress> queryUserAdress(String userId) {
        System.out.println("进入服务提供者UserServiceImpl>queryUserAdress");

        List<UserAdress> userAdresses = new ArrayList<>();

        UserAdress userAdress1= new UserAdress("JONY","13890872908","北京朝阳区");
        UserAdress userAdress2= new UserAdress("Lily","18979019897","浙江杭州余杭区");

        userAdresses.add(userAdress1);
        userAdresses.add(userAdress2);

        return userAdresses;
    }
}
搭建服务提供者 zzjmay-dubbo-consumer
第一步 引入dubbo的springboot的包
    <dependency>
		<groupId>com.alibaba.boot</groupId>
		<artifactId>dubbo-spring-boot-starter</artifactId>
		<version>0.2.0</version>
	</dependency>
	<!--引用spring的web模块-->
	<dependency>
		<groupId>org.springframework.boot</groupId>
		<artifactId>spring-boot-starter-web</artifactId>
		<version>1.4.7.RELEASE</version>
	</dependency>

第二步 配置dubbo的服务端属性
server.port=8090
##配置应用名称
dubbo.application.name=zzjmay-dubbo-consumer

dubbo.registry.address=zookeeper://47.99.218.199:2181
第三步 消费端引用对应的生产者提供的服务 @Reference
@Service
public class OrderServiceImpl implements OrderService {

    /**
     * 引用dubbo的服务
     */
    @Reference(timeout = 5000)
    UserService userService;

    @Override
    public List<UserAdress> queryUserInfo(String userId) {
        return userService.queryUserAdress(userId);
    }
}
最后分别启动生产者,消费者即可

在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值