您好,登錄后才能下訂單哦!
這篇文章給大家介紹Ribbon如何負載均衡地消費microservice-provider-user,內容非常詳細,感興趣的小伙伴們可以參考借鑒,希望對大家能有所幫助。
要想消費microservice-provider-user的服務是很簡單的,我們只需要使用RestTemplate即可,或者例如HttpClient之類的http工具也是可以的。但是在集群環境下,我們必然是每個服務部署多個實例,那么服務消費者消費服務提供者時的負載均衡又要如何做呢?
1.準備工作
啟動注冊中心:microservice-discovery-eureka
啟動服務提供方:microservice-provider-user
修改microservice-provider-user的端口為8001,另外啟動一個實例
此時,訪問http://discovery:8761
可以在Eureka中看到microservice-provider-user有兩個實例在運行。
下面我們創建一個新的微服務(microservice-consumer-movie-*),負載均衡地消費microservice-provider-user的服務。
2.Ribbon介紹
Ribbon是Netflix發布的開源項目,主要功能是提供客戶端的軟件負載均衡算法,將Netflix的中間層服務連接在一起。Ribbon客戶端組件提供一系列完善的配置項如連接超時,重試等。簡單的說,就是在配置文件中列出Load Balancer后面所有的機器,Ribbon會自動的幫助你基于某種規則(如簡單輪詢,隨即連接等)去連接這些機器。我們也很容易使用Ribbon實現自定義的負載均衡算法。簡單地說,Ribbon是一個客戶端負載均衡器。Ribbon工作時分為兩步:第一步先選擇 Eureka Server, 它優先選擇在同一個Zone且負載較少的Server;第二步再根據用戶指定的策略,在從Server取到的服務注冊列表中選擇一個地址。其中Ribbon提供了三種策略:輪詢、斷路器和根據響應時間加權。
3.開發
創建一個Maven項目,并在pom.xml中加入如下內容:
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://m
aven.apache.org/xsd/maven-4.0.0.xsd">
4.0.0
microservice-consumer-movie-ribbon
jar
com.itmuch.cloud
spring-cloud-microservice-study
0.0.1-SNAPSHOT
org.springframework.cloud
spring-cloud-starter-eureka
org.springframework.cloud
spring-cloud-starter-ribbon
org.springframework.boot
spring-boot-starter-actuator
啟動類:MovieRibbonApplication.java。使用@LoadBalanced注解,為RestTemplate開啟負載均衡的能力。
@SpringBootApplication
@EnableDiscoveryClient
public class MovieRibbonApplication {
/**
* 實例化RestTemplate,通過@LoadBalanced注解開啟均衡負載能力.
* @return restTemplate
*/
@Bean
@LoadBalanced
public RestTemplate restTemplate() {
return new RestTemplate();
}
public static void main(String[] args) {
SpringApplication.run(MovieRibbonApplication.class, args);
}
}
實體類:User.java
public class User {
private Long id;
private String username;
private Integer age;
...
// getters and setters
}
Ribbon的測試類:RibbonService.java
@Service
public class RibbonService {
@Autowired
private RestTemplate restTemplate;
public User findById(Long id) {
// http://服務提供者的serviceId/url
return this.restTemplate.getForObject("http://microservice-p
rovider-user/" + id, User.class);
}無錫×××醫院 https://yyk.familydoctor.com.cn/20612/
}
controller:RibbonController.java
@RestController
public class RibbonController {
@Autowired
private RibbonService ribbonService;
@GetMapping("/ribbon/{id}")
public User findById(@PathVariable Long id) {
return this.ribbonService.findById(id);
}
}
application.yml
server:
port: 8010
spring:
application:
name: microservice-consumer-movie-ribbon
eureka:
client:
serviceUrl:
instance:
preferIpAddress: true
啟動后,訪問多次http://localhost:8010/ribbon/1,返回結果:
{
"id": 1,
"username": "Tom",
"age": 12
}
然后打開兩個microservice-provider-user實例的控制臺,發現兩個實例都輸出了類似如下的日志內容:
Hibernate: select user0_.id as id1_0_0_, user0_.age as age2_0_0_,
user0_.username as username3_0_0_ from user user0_ where user0_.id=?
2016-09-13 21:38:56.719 TRACE 17404 --- [nio-8000-exec-1] o.h.type.descriptor.sql.BasicBinder :
binding parameter [1] as [BIGINT] - [1]
2016-09-13 21:38:56.720 TRACE 17404 --- [nio-8000-exec-1] o.h.type.descriptor.sql.BasicExtractor :
extracted value ([age2_0_0_] : [INTEGER]) - [12]
2016-09-13 21:38:56.720 TRACE 17404 --- [nio-8000-exec-1] o.h.type.descriptor.sql.BasicExtractor :
extracted value ([username3_0_0_] : [VARCHAR]) - [Tom]
2016-09-13 21:39:10.588 INFO 17404 --- [trap-executor-0] c.n.d.s.r.aws.ConfigClusterResolver :
Resolving eureka endpoints
via configuration
至此,我們已經通過Ribbon在客戶端側實現了均衡負載。
關于Ribbon如何負載均衡地消費microservice-provider-user就分享到這里了,希望以上內容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。