springboot 系列之 dubbo
dubbo 简介
Apache Dubbo™ 是一款高性能 Java RPC 框架。
(1)面向接口代理的高性能 RPC 调用
提供高性能的基于代理的远程调用能力,服务以接口为粒度,为开发者屏蔽远程调用底层细节。
(2)智能负载均衡
内置多种负载均衡策略,智能感知下游节点健康状况,显著减少调用延迟,提高系统吞吐量。
(3)服务自动注册与发现
支持多种注册中心服务,服务实例上下线实时感知。
(4)高度可扩展能力
遵循微内核 + 插件的设计原则,所有核心能力如 Protocol、Transport、Serialization 被设计为扩展点,平等对待内置实现和第三方实现。
(5)运行期流量调度
内置条件、脚本等路由策略,通过配置不同的路由规则,轻松实现灰度发布,同机房优先等功能。
(6)可视化的服务治理与运维
提供丰富服务治理、运维工具:随时查询服务元数据、服务健康状态及调用统计,实时下发路由策略、调整配置参数。
dubbo 使用(使用 dubbo 直连方式)
1、创建 springboot 项目名字为:dubbo-service
2、添加 dubbo 依赖
<dependency>
<groupId>org.apache.dubbo</groupId>
<artifactId>dubbo-spring-boot-starter</artifactId>
<version>2.7.7</version>
</dependency>
3、创建 dubbo 提供者类 User、UserInfoService、UserInfoServiceImpl
@Data
@Builder
@NoArgsConstructor
@AllArgsConstructor
public class User {
private Long id;
private String userName;
private String password;
@JsonFormat(pattern="yyyy-MM-dd HH:mm:ss",timezone="GMT+8")
private LocalDateTime createTime;
}
public interface UserInfoService {
/**
* 获取用户信息
*
* @return
*/
User getUserInfo();}
@Component
@Service(version = "1.0.0", timeout = 10000, interfaceClass = UserInfoService.class)
public class UserInfoServiceImpl implements UserInfoService {
@Override
public User getUserInfo() {return User.builder().userName("name").password(UUID.randomUUID().toString().replaceAll("-", ""))
.createTime(LocalDateTime.now()).build();}
}
4、创建 dubbo 消费者类 DubboController
@RestController
public class DubboController {@Reference(version = "1.0.0", url = "dubbo://127.0.0.1:12345")
private UserInfoService userInfoService;
@RequestMapping("userInfo")
public User userInfo(){return userInfoService.getUserInfo();
}
}
5、修改 application.properties 配置文件
spring.application.name=dubbo-service
dubbo.scan.base-packages=com.wotrd.dubboprovider.service
# Dubbo Protocol
dubbo.protocol.name=dubbo
dubbo.protocol.port=12345
## Dubbo Registry
dubbo.registry.address=N/A
6、启动服务,访问地址 http://localhost:8080/userInfo 测试得到返回结果成功
{"id":null,"userName":"name","password":"487e5550715b44c3ab1e2a90cacc5d25","createTime":"2020-06-21 23:10:44"}