Apache Dubbo-快速入门(1)

一、简介

Apache Dubbo是一个分布式都rpc框架,它提供了服务治理,比如服务的注册,监控、路由、容错等。
促使Apache Dubbo诞生的原因有2个:
1.服务的越来越多,消费方调用服务提供方,需要在配置文件中维护服务提供方的url地址,当提供方出现故障或者动态扩容时,所有消费方都要更新配置文件中的url地址。这个时候,实现服务的上下线感知及服务地址的动态维护就很重要了。
2.随着用户量的增大,后端服务为了支撑更大的访问量,会增加服务器来扩容,但是那些服务要扩容哪些服务要缩容,需要一个依据。也就是说需要知道每个服务的访问量和响应时间。这个时候需要一种监控手段,使得监控的数据作为容量规划的参考值。

架构图:
在这里插入图片描述

二、实现远程通信

创建2个普通的maven工程。一个dubbo-order,一个dubbo-user.我们要订单order调用用户

user:
在这里插入图片描述
在用户的dubbo-api中定义一个接口。并通过maven install 安装到本地,如果搭建l了私服,可以通过 maven deploy来发布

public interface UserService {
    String getNameById(String userId);
}

在用户的dubbo-service中编写实现,并添加dubbo-api的依赖,和dubbo的依赖

 		<dependency>
            <artifactId>dubbo-api</artifactId>
            <groupId>com.kangping.dubbo</groupId>
            <version>1.0-SNAPSHOT</version>
        </dependency>
        <dependency>
            <groupId>org.apache.dubbo</groupId>
            <artifactId>dubbo</artifactId>
            <version>2.7.5</version>
        </dependency>

创建resource/MATE-INFO/spring/user-provider.xml

<?xml version="1.0" encoding="UTF-8"?>
<!-- 添加 DUBBO SCHEMA -->
<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="user-service"/>

    <!-- 连接到哪个本地注册中心 N/A表示不注册 -->
    <dubbo:registry address="N/A"/>

    <!-- 用dubbo协议在20880端口暴露服务 -->
    <dubbo:protocol name="dubbo" port="28080"/>

    <!-- 声明需要暴露的服务接口 -->
    <dubbo:service timeout="3000" interface="com.kangping.dubbo.user.api.UserService" ref="userService"/>

    <!-- bean注册 -->
    <bean id="userService" class="com.kangping.dubbo.user.service.UserServiceImpl" />

</beans>

编写启动类

public class DobboMain {
    public static void main(String[] args) throws IOException {
        ClassPathXmlApplicationContext context =
                new ClassPathXmlApplicationContext("classpath*:/META-INFO/spring/user-provider.xml");
        context.start();
        System.in.read();
       // Main.main(args);
    }
}

启动成功后,我们可以看到dubbo发布的地址
dubbo://192.168.2.168:28080/com.kangping.dubbo.user.api.UserService
在这里插入图片描述

order:在这里插入图片描述

在order-service添加依赖

 		<dependency>
            <artifactId>dubbo-api</artifactId>
            <groupId>com.kangping.dubbo</groupId>
            <version>1.0-SNAPSHOT</version>
        </dependency>
        <dependency>
            <groupId>org.apache.dubbo</groupId>
            <artifactId>dubbo</artifactId>
            <version>2.7.5</version>
        </dependency>

创建resource/MATE-INFO/spring/consumer.xml

<?xml version="1.0" encoding="UTF-8"?>
<!-- 添加 DUBBO SCHEMA -->
<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="user-service"/>

    <!-- 连接到哪个本地注册中心 N/A表示不注册 -->
    <dubbo:registry address="N/A"/>

    <!-- 生成远程服务代理 -->
    <dubbo:reference 
    id="userService" 
    interface="com.kangping.dubbo.user.api.UserService"  
     url="dubbo://192.168.2.168:28080/com.kangping.dubbo.user.api.UserService" />

</beans>

编写启动类

public class OrderMain {

    public static void main(String[] args) {
        ClassPathXmlApplicationContext context = new ClassPathXmlApplicationContext("classpath*:/META-INFO/spring/consumer.xml");
        UserService userService = (UserService) context.getBean("userService");
        System.out.println(userService.getNameById("111"));
    }
}
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值