JAVA springboot ssm b2b2c多使用者商城系統原始碼:服務消費(基礎) ...
使用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多使用者商城系統原始碼-commonservice-sso服務搭建(一)JavaSpring BootSSM原始碼
- JAVAspringbootssmb2b2c多使用者商城系統原始碼:服務消費(基礎)JavaSpring BootSSM原始碼
- (十一)JAVA springboot ssm b2b2c多使用者商城系統原始碼:服務閘道器Zuul高階篇JavaSpring BootSSM原始碼Zuul
- JAVA springcloud ssm b2b2c多使用者商城系統原始碼 (四)SpringBoot 整合JPAJavaGCCloudSSM原始碼Spring Boot
- JAVA springboot ssm b2b2c多使用者商城系統原始碼(三)SpringBoot用JdbcTemplates訪問MysqlJavaSpring BootSSM原始碼JDBCMySql
- JAVA ssm b2b2c多使用者商城系統原始碼-搭建eurekaJavaSSM原始碼
- JAVA springcloud ssm b2b2c多使用者商城系統原始碼(一)構建第一個SpringBoot工程JavaGCCloudSSM原始碼Spring Boot
- Java多使用者商城系統B2B2C原始碼Java原始碼
- JAVA springcloud b2b2c多使用者商城系統原始碼(五)springboot整合 beatlsqlJavaGCCloud原始碼Spring BootTLSSQL
- (十一)JAVA ssm b2b2c多使用者商城系統原始碼-docker部署spring cloud專案JavaSSM原始碼DockerSpringCloud
- Java springboot B2B2C o2o多使用者商城 springcloud架構 (三) 服務消費者(Feign)JavaSpring BootGCCloud架構
- Java多使用者商城系統B2B2C原始碼-(九)服務鏈路追蹤(Spring Cloud Sleuth)Java原始碼SpringCloud
- java springboot b2b2c shop 多使用者商城系統原始碼-(五)路由閘道器(zuul)JavaSpring Boot原始碼路由Zuul
- java springboot b2b2c shop 多使用者商城系統原始碼 (二)Spring Boot配置檔案詳解JavaSpring Boot原始碼
- java springcloud b2b2c shop 多使用者商城系統原始碼-介紹StreamJavaSpringGCCloud原始碼
- JAVA springcloud ssm b2b2c多使用者商城系統-docker-hystrix-dashboard-turbine(九)JavaSpringGCCloudSSMDocker
- 十六)java springboot b2b2c shop 多使用者商城系統原始碼-使用spring cloud Bus重新整理配置JavaSpring Boot原始碼Cloud
- JAVA springboot微服務b2b2c電子商務系統(二)服務消費者(rest+ribbon)JavaSpring Boot微服務REST
- JAVA springcloud b2b2c多使用者商城系統原始碼(二十三)非同步方法JavaSpringGCCloud原始碼非同步
- java B2B2C Springboot多租戶電子商城系統JavaSpring Boot
- java B2B2C 原始碼 多級分銷springmvc mybatis多租戶電子商城系統---服務閘道器zuulJava原始碼SpringMVCMyBatisZuul
- JAVA電商 B2B2C商城系統 多使用者商城系統 直播帶貨Java
- (十一)JAVA springboot ssm b2b2c多使用者商城系統 - SSO單點登入之OAuth2.0登入流程(2)JavaSpring BootSSMOAuth
- (十二)java springboot b2b2c shop 多使用者商城系統原始碼- SSO單點登入之OAuth2.0 登出流程(3)JavaSpring Boot原始碼OAuth
- (九)Java版本多使用者B2B2C商城原始碼- commonservice-config配置服務搭建Java原始碼
- java B2B2C 原始碼多租戶電子商城系統-熔斷器HystrixJava原始碼
- java B2B2C Springboot多租戶電子商城系統-Consul 介紹JavaSpring Boot
- 企業級javaspringbootb2bc商城系統開源原始碼二次開發:服務消費(Ribbon)JavaSpring Boot原始碼
- java版 電子商務Springcloud分散式微服務多使用者商城系統-Springboot專案打包JavaGCCloud分散式微服務Spring Boot
- (十八) Java版本多使用者B2B2C商城原始碼-後臺管理基礎功能簡介Java原始碼
- Java B2B2C多使用者商城springboot架構——springcloud整合busJavaSpring Boot架構GCCloud
- thinkphp商城系統原始碼多使用者三級分銷PHP原始碼
- java B2B2C 原始碼多租戶電子商城系統-Spring Cloud元件詳解Java原始碼SpringCloud元件
- java B2B2C 原始碼多租戶電子商城系統-Kafka基本使用介紹Java原始碼Kafka
- java B2B2C Springboot多租戶電子商城系統- gateway之filter篇JavaSpring BootGatewayFilter
- Java B2B2C多使用者商城 springcloud架構(七)springboot開啟宣告式事務JavaGCCloud架構Spring Boot
- java B2B2C 原始碼 多級分銷Springcloud多租戶電子商城系統-KAFKA介紹Java原始碼SpringGCCloudKafka
- 多使用者商城系統原始碼_業務邏輯功能思維導圖_OctShop原始碼