在Spring Cloud Finchley版本中,Ribbon是Spring Cloud Netflix模块的一部分,用于实现客户端的负载均衡。
以下是一个使用Ribbon实现负载均衡的简单示例:
- 添加依赖到你的
pom.xml
:
<dependencies>
<!-- 其他依赖 -->
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-netflix-ribbon</artifactId>
</dependency>
</dependencies>
- 配置一个Ribbon客户端,在
application.properties
中指定服务列表:
# 服务名与服务实例列表
service-id.ribbon.listOfServers=http://server-1:port, http://server-2:port
- 使用
@LoadBalanced
注解来配置RestTemplate实例,以支持Ribbon负载均衡:
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.web.client.RestTemplate;
@Configuration
public class Config {
@Bean
public RestTemplate restTemplate() {
return new RestTemplate();
}
}
- 使用RestTemplate进行服务调用:
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
import org.springframework.web.client.RestTemplate;
@Service
public class MyService {
@Autowired
private RestTemplate restTemplate;
public String callService() {
return restTemplate.getForObject("http://SERVICE-ID/some-path", String.class);
}
}
在上述示例中,SERVICE-ID
是Ribbon客户端的服务ID,它会被Ribbon用来与配置的服务实例进行负载均衡。RestTemplate
会自动使用Ribbon进行负载均衡,发送请求到服务实例。