1.Ribbon 是什么
<!--ribbon-->
<!-- https://mvnrepository.com/artifact/org.springframework.cloud/spring-cloud-starter-ribbon -->
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-ribbon</artifactId>
<version>1.4.7.RELEASE</version>
</dependency>
<!--Eureka 服务提供者-->
<!-- https://mvnrepository.com/artifact/org.springframework.cloud/spring-cloud-starter-eureka -->
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-eureka</artifactId>
<version>1.4.7.RELEASE</version>
</dependency>
2.编写 application.yml
# Eureka
eureka:
client:
# 不向注册中心注册自己
register-with-eureka: false
# 配置 可连接的注册中心
service-url:
defaultZone: http://127.0.0.1:7001/eureka/,http://127.0.0.2:7002/eureka/
3.在主启动类上添加 Eureka 启动项 : @EnableEurekaClient
4.在之前把 RestTemplate 注册到 Bean 的配置方法上添加一个注解
5.修改控制层
/**提供者 URL 的前缀
*
* 不使用 Ribbon 时 ,这里就是第一中写法
*
* 使用 Ribbon 实现负载均衡 时,这里就不能写死为一个地址,
* 而需要通过注册中心的服务名来访问
* 服务名:在 提供者 YML 文件中配置的 spring:application:name: 的值
* 或者 监控页面的 Application 字段值
*/
//private static final String REST_URL_PREFIX = "http://localhost:8081";
private static final String REST_URL_PREFIX = "http://SpringCloud-02-provider";
3.自定义策略(简单示例)
public class DiyRule extends AbstractLoadBalancerRule {
public Server choose(ILoadBalancer lb, Object key) {
if (lb == null) {
return null;
} else {
Server server = null;
while(server == null) {
if (Thread.interrupted()) {
return null;
}
// 获得可获得(活着的)的服务
List<Server> upList = lb.getReachableServers();
// 获得所有的服务
List<Server> allList = lb.getAllServers();
int serverCount = allList.size();
if (serverCount == 0) {
return null;
}
//==上面是写死的======中间是修改部分==================
System.out.println("自定义的 Rule");
System.out.println(upList.size());
// 访问某一个提供者的次数
int times = 0;
// 提供者的下标
int index = 0;
// 从活着的服务中随机获取一个
server = (Server)upList.get(index);
if (times < 4){
times++;
}else {
times = 1;
index = (index + 1) % upList.size();
}
//==下面是写死的======中间是修改部分===================
if (server == null) {
Thread.yield();
} else {
if (server.isAlive()) {
return server;
}
server = null;
Thread.yield();
}
}
return server;
}
}
@Override
public void initWithNiwsConfig(IClientConfig iClientConfig) {
}
@Override
public Server choose(Object o) {
return null;
}
}
2.MyRule 类
@Configuration
public class CustomizedRule {
/**
* 修改默认的负载均衡策略
*/
@Bean
public IRule customize(){
// 先使用已经实现的策略——随机
return new DiyRule();
}
}
3.在主启动类上添加
// configuration:标注 Rule 的配置类 ; name:标注需要配置的服务名
@RibbonClient(name = "SPRINGCLOUD-PROVIDER", configuration = CustomizedRule.class)
Eureka 和 Ribbon 整合以后,在消费端,就不需要关系请求服务的 IP地址 和 端口号了,就只需要知道服务名称,直接调用即可