Dubbo 分布式服务框架(入门)

1.1 概念

Dubbo 是一个分布式服务框架,致力于提供高性能和透明化的RPC远程服务调用方案,可以和spring框架无缝集成。
Dubbo 采用的是一种非常简单的模型,要么是提供方提供服务,要么是消费方消费服务,所以基于这一点可以抽象出服务提供方(Provider)和服务消费方(Consumer)两个角色。
Dubbo 致力于提供高性能和透明化的RPC远程服务调用方案,以及SOA服务治理方案;

①服务定义: 服务是围绕服务提供方和服务消费方的,服务提供方实现服务,而服务消费方调用服务。

②服务注册: 对于服务提供方,它需要发布服务,而且由于应用系统的复杂性,服务的数量、类型也不断膨胀;对于服务消费方,它最关心如何获取到它所需要的服务,而面对复杂的应用系统,需要管理大量的服务调用。而且,对于服务提供方和服务消费方来说,他们还有可能兼具这两种角色,即需要提供服务,又需要消费服务。
通过将服务统一管理起来,可以有效地优化内部应用对服务发布/使用的流程和管理。服务注册中心有如下几种类型可供选择:
Multicast注册中心(测试)、Zookeeper注册中心(官方推荐)、Redis注册中心、Simple注册中心

③服务监控
无论是服务提供方,还是服务消费方,他们都需要对服务调用的实际状态进行有效的监控,从而改进服务质量。

④远程通信与信息交换
远程通信需要指定通信双方所约定的协议,在保证通信双方理解协议语义的基础上,还要保证高效、稳定的消息传输。Dubbo继承了当前主流的网络通信框架,主要包括如下几个:
Mina、Netty、Grizzly
在这里插入图片描述

1.2案例解析

在这里插入图片描述

1.2.1注册中心
public interface service {
    public String sayHello(String msg);
}
1.2.2服务提供方

(一)实现类

/*
* 服务提供方
* */
public class UserServiceImpl implements service {
    /*
    *
    * 具体方法的实现
    *
    * */
    public String sayHello(String msg) {
        System.out.println("远程调用服务:"+msg);
        return "hello"+msg;
    }
}

(二)配置文件

<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="userService_provider"/>
    <!--指定注册中心的地址-->
    <dubbo:registry address="multicast://224.5.6.7:1234" />
    <!--使用协议和端口号-->
    <dubbo:protocol name="dubbo" port="20880"/>
    <!--发布服务接口  ref放实现类-->
    <dubbo:service interface="cn.tx.service.service" ref="userService"/>
    <!--使用bean管理实现类-->
    <bean id="userService" class="cn.tx.service.impl.UserServiceImpl"/>

</beans>

(三)测试方法

public class UserServletBoot {
    public static void main(String[] args) throws IOException {
        //加载spring的配置文件
        ApplicationContext ac = new ClassPathXmlApplicationContext("classpath:dubbo_provider.xml");
        //阻塞
        System.in.read();
    }
}
1.2.3服务消费方

(一)配置文件

<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="userService_consumer"/>
    <!--注册中心的地址-->
    <dubbo:registry address="multicast://224.5.6.7:1234" />
    <!--可以使用服务-->
    <dubbo:reference interface="cn.tx.service.service" id="userService"/>
</beans>

(二)测试方法

@RunWith(SpringJUnit4ClassRunner.class)
@ContextConfiguration("classpath:dubbo_consumer.xml")
public class ConsumerTest {
    @Autowired
    private service service;
    @Test
    public void run1(){
        String msg = service.sayHello("亮哥爱玩");
        System.out.println(msg);
    }
}
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

java亮小白1997

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值