springboot系列之dubbo

springboot系列之dubbo

dubbo簡介

Apache Dubbo™ 是一款高性能Java RPC框架。
(1)面向接口代理的高性能RPC調用
   提供高性能的基於代理的遠程調用能力,服務以接口爲粒度,爲開發者屏蔽遠程調用底層細節。
(2)智能負載均衡
   內置多種負載均衡策略,智能感知下游節點健康情況,顯著減小調用延遲,提升系統吞吐量。
(3)服務自動註冊與發現
   支持多種註冊中心服務,服務實例上下線實時感知。
(4)高度可擴展能力
   遵循微內核+插件的設計原則,全部核心能力如Protocol、Transport、Serialization被設計爲擴展點,平等對待內置實現和第三方實現。
(5)運行期流量調度
   內置條件、腳本等路由策略,經過配置不一樣的路由規則,輕鬆實現灰度發佈,同機房優先等功能。
(6)可視化的服務治理與運維
   提供豐富服務治理、運維工具:隨時查詢服務元數據、服務健康狀態及調用統計,實時下發路由策略、調整配置參數。html

dubbo使用(使用dubbo直連方式)

一、建立springboot項目名字爲:dubbo-service
二、添加dubbo依賴spring

<dependency>
     <groupId>org.apache.dubbo</groupId>
     <artifactId>dubbo-spring-boot-starter</artifactId>
     <version>2.7.7</version>
</dependency>

三、建立dubbo提供者類User、UserInfoService、UserInfoServiceImplapache

@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();
    }
}

四、建立dubbo消費者類DubboControllerspringboot

@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();
    }
}

五、修改application.properties配置文件app

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

六、啓動服務,訪問地址http://localhost:8080/userInfo測試獲得返回結果成功負載均衡

{"id":null,"userName":"name","password":"487e5550715b44c3ab1e2a90cacc5d25","createTime":"2020-06-21 23:10:44"}

有問題,請留言! 我的博客地址

相關文章
相關標籤/搜索