Perfree

Perfree

未设置

未设置

54 文章数
72 评论数

SpringCloud (二) : Ribbon实现客户端的负载均衡

perfree
2019-02-17 / 0 评论 / 2599 阅读 / 0 点赞

接上一篇,假设我们的MY-CLIENT服务的访问量剧增,用一个服务已经无法承载, 我们可以把这个服务做成一个集群,接下来我们就简单的测试一下,接着上一篇的项目开始改:

启动server

本篇源码地址case-02-ribbon 先启动我们的spring-cloud-server项目,接着再向下进行

修改spring-cloud-client项目

这里只改动HelloController类,让它返回内容时,带上它的端口号

package com.perfree.controller;

import org.springframework.beans.factory.annotation.Value;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;

@RestController
public class HelloController {
	
	@Value("${server.port}")
	private String port;
	
	@RequestMapping("/hello")
	public String hello() {
		return "Hello from " + port;
	}
}

为了规范,我们将配置文件里的应用名改一下

#端口号
server.port=8882
#应用名称
spring.application.name=MY-CLIENT
#服务中心地址
eureka.client.service-url.defaultZone=http://localhost:8881/eureka

改完之后,我们启动spring-cloud-client,启动成功之后,再进行修改它配置文件,将端口修改为8884,如下

#端口号
server.port=8884
#应用名称
spring.application.name=MY-CLIENT
#服务中心地址
eureka.client.service-url.defaultZone=http://localhost:8881/eureka

再启动一次项目,这样,注册中心就显示两个MY-CLIENT服务了

改造spring-cloud-ribbon

在启动类restTemplate方法上添加@LoadBalanced表示开启负载均衡

package com.perfree;

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.client.discovery.EnableDiscoveryClient;
import org.springframework.cloud.client.loadbalancer.LoadBalanced;
import org.springframework.context.annotation.Bean;
import org.springframework.web.client.RestTemplate;

@SpringBootApplication
@EnableDiscoveryClient
public class SpringCloudRibbonApplication {

	public static void main(String[] args) {
		SpringApplication.run(SpringCloudRibbonApplication.class, args);
	}
	
	//注入RestTemplate
	@Bean
	@LoadBalanced//开启负载均衡
	public RestTemplate restTemplate() {
		return new RestTemplate();
	}
}

修改HelloController类以应用名方式调用接口,如下

package com.perfree.controller;

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
import org.springframework.web.client.RestTemplate;

@RestController
public class HelloController {
	
	@Autowired
	private RestTemplate restTemplate;
	
	@RequestMapping("/")
	public String hello() {
		return restTemplate.getForEntity("http://MY-CLIENT/hello", String.class).getBody();
	}
}

接着启动该项目

测试访问

接下来测试访问http://127.0.0.1:8883/ 第一次访问结果: 第二次访问结果: 第三次: 第四次: 这样,一个简单的负载均衡就实现了

上一篇 下一篇
评论
来首音乐
最新回复
光阴似箭
今日已经过去小时
这周已经过去
本月已经过去
今年已经过去个月