Ribbon是一个基于HTTP和TCP客户端的负载均衡器,默认使用轮询的方式
将eureka服务提供者启动两个不同端口实现集群,方便测试
- 在父工程下创建一个项目
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<parent>
<artifactId>springcloud-demo</artifactId>
<groupId>demo.cloud</groupId>
<version>1.0-SNAPSHOT</version>
</parent>
<modelVersion>4.0.0</modelVersion>
<artifactId>ribbon-service</artifactId>
<name>ribbon-service</name>
<dependencies>
<!-- ribbon依赖 -->
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-netflix-ribbon</artifactId>
</dependency>
<!-- eureka-client依赖,默认依赖ribbon -->
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
</dependencies>
</project>
- 修改application.yml文件
server:
port: 8765
spring:
application:
#服务名称
name: ribbon-service
eureka:
client:
#是否将自己注册到Eureka服务中
register-with-eureka: true
#是否从Eureka服务中获取注册信息
fetch-registry: true
#Eureka注册中心的地址,多个注册中心用,隔开
serviceUrl:
defaultZone: http://localhost:8761/eureka/
- 修改启动程序
使用@EnableDiscoveryClient注解向注册中心注册,
初始化RestTemplate,@LoadBalanced注解开启负载均衡功能,
开启后Ribbon将拦截RestTemplate发起的请求,并实现负载均衡
@SpringBootApplication
@EnableDiscoveryClient
public class RibbonServiceApplication {
public static void main(String[] args) {
SpringApplication.run(RibbonServiceApplication.class, args);
}
@Bean
@LoadBalanced
public RestTemplate restTemplate(){
return new RestTemplate();
}
}
- 创建测试接口
Ribbon中访问接口:http://{服务名称}/接口,服务名称代替地址和端口
@RestController
public class TestController {
@Autowired
private RestTemplate restTemplate;
@GetMapping("test")
public String test(){
String str = restTemplate.getForObject("http://eureka-service/hello", String.class);
return str;
}
}
- 测试接口
浏览器访问http://localhost:8765/testport:8763
port:8764
作者公众号