JAVAspringbootssmb2b2c多使用者商城系統原始碼:服務消費(基礎)
使用LoadBalancerClient
在Spring Cloud Commons中提供了大量的與服務治理相關的抽象介面,包括DiscoveryClient、這裡我們即將介紹的LoadBalancerClient等。對於這些介面的定義我們在上一篇介紹服務註冊與發現時已經說過,Spring Cloud做這一層抽象,很好的解耦了服務治理體系,使得我們可以輕易的替換不同的服務治理設施。
從LoadBalancerClient介面的命名中,我們就知道這是一個負載均衡客戶端的抽象定義,下面我們就看看如何使用Spring Cloud提供的負載均衡器客戶端介面來實現服務的消費。
下面的例子,我們將利用上一篇中構建的eureka-server作為服務註冊中心、eureka-client作為服務提供者作為基礎。
我們先來建立一個服務消費者工程,命名為:eureka-consumer。並在pom.xml中引入依賴(這裡省略了parent和dependencyManagement的配置):
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-eureka</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-actuator</artifactId>
</dependency>
配置application.properties,指定eureka註冊中心的地址:
spring.application.name=eureka-consumer
server.port=2101
eureka.client.serviceUrl.defaultZone=http://localhost:1001/eureka/
建立應用主類。初始化RestTemplate,用來真正發起REST請求。@EnableDiscoveryClient註解用來將當前應用加入到服務治理體系中。
@EnableDiscoveryClient
@SpringBootApplication
public class Application {
@Bean
public RestTemplate restTemplate() {
return new RestTemplate();
}
public static void main(String[] args) {
new SpringApplicationBuilder(Application.class).web(true).run(args);
}
}
建立一個介面用來消費eureka-client提供的介面:
@RestController
public class DcController {
@Autowired
LoadBalancerClient loadBalancerClient;
@Autowired
RestTemplate restTemplate;
@GetMapping("/consumer")
public String dc() {
ServiceInstance serviceInstance = loadBalancerClient.choose("eureka-client");
String url = "http://" + serviceInstance.getHost() + ":" + serviceInstance.getPort() + "/dc";
System.out.println(url);
return restTemplate.getForObject(url, String.class);
}
}
可以看到這裡,我們注入了LoadBalancerClient和RestTemplate,並在/consumer介面的實現中,先通過loadBalancerClient的choose函式來負載均衡的選出一個eureka-client的服務例項,這個服務例項的基本資訊儲存在ServiceInstance中,然後通過這些物件中的資訊拼接出訪問/dc介面的詳細地址,最後再利用RestTemplate物件實現對服務提供者介面的呼叫。
在完成了上面你的程式碼編寫之後,讀者可以將eureka-server、eureka-client、eureka-consumer都啟動起來,然後訪問http://localhost:2101/consumer ,來跟蹤觀察eureka-consumer服務是如何消費eureka-client服務的/dc介面的。
consul版的示例,可檢視git倉庫中的consul-client和consul-consumer
Spring Cloud大型企業分散式微服務雲構建的B2B2C電子商務平臺原始碼
相關文章
- JAVA springboot ssm b2b2c多使用者商城系統原始碼:服務消費(基礎) ...JavaSpring BootSSM原始碼
- thinkphp商城系統原始碼多使用者三級分銷PHP原始碼
- 企業級javaspringbootb2bc商城系統開源原始碼二次開發:服務消費(Ribbon)JavaSpring Boot原始碼
- Spring Cloud構建微服務架構—服務消費基礎SpringCloud微服務架構
- Java多使用者商城系統B2B2C原始碼Java原始碼
- Java多使用者商城系統B2B2C原始碼-(九)服務鏈路追蹤(Spring Cloud Sleuth)Java原始碼SpringCloud
- javaspringbootb2b2cshop多使用者商城系統原始碼JavaSpring Boot原始碼
- 驚喜釋出:koahub原始碼交易平臺迅貓多使用者商城系統3.0[原始碼]原始碼
- 電商助力神器——|多使用者商城原始碼原始碼
- 多使用者商城系統原始碼_業務邏輯功能思維導圖_OctShop原始碼
- TPshop2.0 免費開源商城系統原始碼原始碼
- (十五)JAVA springboot ssm b2b2c多使用者商城系統原始碼-commonservice-sso服務搭建(一)JavaSpring BootSSM原始碼
- 使用多種客戶端消費WCF RestFul服務(一)——服務端客戶端REST服務端
- 多商戶商城開發(功能)丨多商戶商城系統開發(開發方案)丨多商戶商城成品原始碼系統原始碼
- Springcloud電子商城系統 java B2B2C-服務消費者(rest+ribbon)SpringGCCloudJavaREST
- linux核心基礎-系統服務管理Linux
- 基於thinkphp 5.1 開發的多使用者商城系統 仿小米商城模板PHP
- (十一)JAVA springboot ssm b2b2c多使用者商城系統原始碼:服務閘道器Zuul高階篇JavaSpring BootSSM原始碼Zuul
- Spring Cloud構建分散式電子商務平臺:服務消費(基礎)SpringCloud分散式
- JAVA ssm b2b2c多使用者商城系統原始碼-搭建eurekaJavaSSM原始碼
- [程式碼示例]WeMall迅貓多使用者微商城系統
- Php迅貓多使用者商城系統PHP
- php多使用者商城系統推薦PHP
- 簡述多使用者電商系統原始碼原始碼
- 多使用者商城系統定製開發
- java B2B2C 原始碼 多級分銷springmvc mybatis多租戶電子商城系統---服務閘道器zuulJava原始碼SpringMVCMyBatisZuul
- 多商戶商城系統定製(平臺開發)原始碼案例原始碼
- 商城系統原始碼你瞭解多少?原始碼
- 跨境商城系統開發原始碼部署原始碼
- Laravel 原始碼閱讀指南 -- 使用者認證系統 (基礎介紹)Laravel原始碼
- 眾籌app商城開發詳細,眾籌app商城系統開發(原始碼部署),眾籌商城系統原始碼功能APP原始碼
- java springcloud b2b2c shop 多使用者商城系統原始碼-介紹StreamJavaSpringGCCloud原始碼
- Java springboot B2B2C o2o多使用者商城 springcloud架構 (三) 服務消費者(Feign)JavaSpring BootGCCloud架構
- ThinkPHP6 原始碼閱讀(十二):系統服務PHP原始碼
- 使用多種客戶端消費WCF RestFul服務(四)——Jquery篇客戶端RESTjQuery
- NFT商城系統介紹|NFT模式系統原始碼搭建模式原始碼
- dubbo消費者原始碼分析原始碼
- 基於thinkphp開發的wemall微信商城原始碼系統修復PHP原始碼