架构-微服务-服务调用Dubbo

文章目录

  • 前言
  • 一、Dubbo介绍
    • [1. 什么是Dubbo](#1. 什么是Dubbo)
  • 二、实现
    • [1. 提供统一业务api](#1. 提供统一业务api)
    • [2. 提供服务提供者](#2. 提供服务提供者)
    • [3. 提供服务消费者](#3. 提供服务消费者)

前言

服务调用方案--Dubbo

基于 Java 的高性能 RPC分布式服务框架,致力于提供高性能和透明化的
RPC远程服务调用方案,以及SOA服务治理方案。


一、Dubbo介绍

1. 什么是Dubbo

Dubbo是阿里巴巴开源的基于 Java 的高性能 RPC分布式服务框架,致力于提供高性能和透明化的RPC远程服务调用方案,以及SOA服务治理方案。

Spring-cloud-alibaba-dubbo 是基于Spring Cloud Alibaba技术栈对dubbo技术的一种封装,目的在于实现基于RPC的服务调用等。

二、实现

1. 提供统一业务api

java 复制代码
public interface ProductService {
	Product findByPid(Integer pid);
}

2. 提供服务提供者

1 添加依赖

xml 复制代码
<!--dubbo-->
<dependency>
	<groupId>com.alibaba.cloud</groupId>
	<artifactId>spring-cloud-starter-dubbo</artifactId>
</dependency>

2 添加dubbo配置

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

3 编写并暴露服务

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

3. 提供服务消费者

1 添加依赖

xml 复制代码
<!--dubbo-->
<dependency>
	<groupId>com.alibaba.cloud</groupId>
	<artifactId>spring-cloud-starter-dubbo</artifactId>
</dependency

2 添加dubbo配置

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

3 引用服务

java 复制代码
@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 服务调用测试


本文的引用仅限自我学习如有侵权,请联系作者删除。
参考知识
传智教育·黑马程序员


相关推荐
wapicn998 分钟前
微服务架构下的数据核验设计,API接入最佳实践
微服务·云原生·架构
Ghost Face...42 分钟前
龙芯2K1000 SoC启动全流程与架构解析
架构
AI攻城狮1 小时前
对AI泡沫的地狱式批判,你认可吗?
云原生
侠客工坊1 小时前
移动端 RPA 的架构重构:基于侠客工坊多模态视觉大模型的自动化调度系统压测复盘
人工智能·智能手机·重构·架构·rpa·数字员工·侠客工坊
liang_jy2 小时前
Android 架构中的统一分发与策略路由
android·架构
hsjcjh2 小时前
深度技术拆解:2026年Gemini 3.1 Pro镜像官网架构与推理能力全面解析(附国内实测方案)
架构
若兰幽竹3 小时前
【从零开始编写数据库系统:架构设计与实现】第5章:查询执行引擎与火山模型
数据库·架构·数据库内核·toydb
逻辑诗篇3 小时前
破核拆解:PCIE719——基于Xilinx Zynq UltraScale+的高性能SAS扩展卡设计
fpga开发·架构
wenzhangli73 小时前
Ooder A2UI 核心架构深度解析:WEB 拦截层的设计与实现
前端·架构
福大大架构师每日一题3 小时前
openclaw v2026.4.24 发布:Google Meet 深度集成、DeepSeek V4 上线、浏览器自动化与插件架构全面升级
运维·架构·自动化·openclaw