springboot系列之dubbo

原创
2020/06/21 23:48
阅读数 355

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](https://my.oschina.net/difrik)
[@Builder](https://my.oschina.net/u/1245189)
@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"}

有问题,请留言! 个人博客地址

展开阅读全文
加载中

作者的其它热门文章

打赏
0
0 收藏
分享
打赏
0 评论
0 收藏
0
分享
返回顶部
顶部