Dubbo--rpc通信

1 介绍

        Dubbo(Apache Dubbo)是一种用于构建高性能、可扩展、分布式服务的开源RPC(Remote Procedure Call,远程过程调用)框架。它最初由阿里巴巴集团开发并于2011年开源,现在由Apache软件基金会进行维护。
        Spring-cloud-alibaba-dubbo 是基于SpringCloudAlibaba技术栈对dubbo技术的一种封装,目的在于实现基于RPC的服务调用。

         Dubbo旨在解决分布式系统中服务之间的通信问题,它提供了一种轻量级、高性能、高可用性的远程调用框架,支持多种通信协议和序列化方式,包括TCP、HTTP、Hessian、JSON等,同时支持多种负载均衡和容错策略,如随机、轮询、一致性哈希、故障转移等,以帮助开发者构建复杂的分布式系统。

        Dubbo还提供了丰富的功能,包括服务注册与发现、负载均衡、服务调用、容错处理、服务治理、监控、追踪等,使得分布式系统的开发、部署和管理变得更加简单和高效。

        Dubbo在众多企业级应用中得到了广泛的应用,包括阿里巴巴、京东、滴滴、美团等,被认为是构建分布式微服务架构的重要工具之一。        

当使用Dubbo进行分布式服务的通信时,可以选择以下几种协议:

Dubbo协议:

Dubbo 协议是 Dubbo 框架自带的二进制 RPC 协议,具有高性能和高效率的特点。使用 Dubbo 协议时,服务提供者和服务消费者之间通过TCP传输协议进行通信。Dubbo 协议使用自定义的编解码方式,将方法调用和参数序列化为二进制数据进行传输,从而实现高效的远程调用。

服务提供者配置:

<dubbo:protocol name="dubbo" port="20880" />

服务消费者配置:

<dubbo:reference id="userService" interface="com.example.UserService" protocol="dubbo" />

HTTP 协议

Dubbo 支持基于 HTTP 的通信,包括 REST 风格的 HTTP 协议和 SOAP 协议。REST 风格的 HTTP 协议通常使用 JSON 或者 XML 作为数据格式进行编解码,而 SOAP 协议则使用 XML。使用 HTTP 协议时,服务提供者和服务消费者之间通过 HTTP 传输协议进行通信,这意味着可以使用标准的 HTTP 工具进行测试和调试。

服务提供者配置:

<dubbo:protocol name="dubbo" port="20880" />

<dubbo:protocol name="http" port="8888" />

服务消费者配置:

<dubbo:reference id="userService" interface="com.example.UserService" protocol="http" url="http://localhost:8888/com.example.UserService" />

Hessian 协议

Hessian 是一种基于二进制的 RPC 协议,Dubbo 支持使用 Hessian 协议进行通信。Hessian 协议具有较好的性能和跨语言支持。使用 Hessian 协议时,服务提供者和服务消费者之间通过 TCP 传输协议进行通信,数据以二进制形式进行编解码。

服务提供者配置:

<dubbo:protocol name="hessian" port="8080" />

服务消费者配置:

<dubbo:reference id="userService" interface="com.example.UserService" protocol="hessian" url="http://localhost:8080/com.example.UserService" />

JSON 协议

Dubbo 还支持使用 JSON 作为数据格式进行编解码,并通过HTTP协议进行通信。JSON 是一种轻量级的数据交换格式,广泛用于 Web 应用中。使用 JSON 协议时,服务提供者和服务消费者之间通过 HTTP 传输协议进行通信,数据以 JSON 格式进行编解码。

服务提供者配置:

<dubbo:protocol name="jsonrpc" port="8888" />

服务消费者配置:

<dubbo:reference id="userService" interface="com.example.UserService" protocol="jsonrpc" url="http://localhost:8888/com.example.UserService" />

2 实现

2.1 提供统一业务api

public interface ProductService {
  Product findByPid(Integer pid);
}

2.2 提供服务提供者

1 添加依赖

<!--dubbo-->
<dependency>
  <groupId>com.alibaba.cloud</groupId>
  <artifactId>spring-cloud-starter-dubbo</artifactId>
</dependency>

2 添加dubbo配置

dubbo:
scan:
 base-packages: com.itheima.service.impl # 开启包扫描
protocols:
 dubbo:
  name: dubbo # 服务协议
  port: -1 # 服务端口
registry:
 address: spring-cloud://localhost # 注册中心

3 编写并暴露服务

//暴露服务:注意这里使用的是dubbo提供的注解@Service,而不是Spring的
@Service
public class ProductServiceImpl implements ProductService {
  @Autowired
  private ProductDao productDao;
  @Override
  public Product findByPid(Integer pid) {
    return productDao.findById(pid).get();
 }
}

2.3 提供服务消费者

1 添加依赖

<!--dubbo-->
<dependency>
  <groupId>com.alibaba.cloud</groupId>
  <artifactId>spring-cloud-starter-dubbo</artifactId>
</dependency>

2 添加dubbo配置

dubbo:
registry:
 address: spring-cloud://localhost # 注册中心
cloud:
 subscribed-services: service-product  # 订阅的提供者名称

3 引用服务

@RestController
@Slf4j
public class OrderController {
  @Autowired
  private OrderService orderService;
  //引用服务
  @Reference
  private ProductService productService;
  @RequestMapping("/order/prod/{pid}")
  public Order order(@PathVariable Integer pid) {
    log.info("接收到{}号商品的下单请求,接下来调用商品微服务查询此商品信息", pid);
    //调用商品微服务,查询商品信息
    Product product = productService.findByPid(pid);
    log.info("查询到{}号商品的信息,内容是:{}", pid, JSON.toJSONString(product));
    //下单(创建订单)
    Order order = new Order();
    order.setUid(1);
    order.setUsername("测试用户");
    order.setPid(pid);
    order.setPname(product.getPname());
    order.setPprice(product.getPprice());
    order.setNumber(1);
    orderService.createOrder(order);
    log.info("创建订单成功,订单信息为{}", JSON.toJSONString(order));
   
    return order;
 }
}

4 服务调用测试

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

chuxuezhe_987

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

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

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

打赏作者

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

抵扣说明:

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

余额充值