Python 官方文档:入门教程 => 点击学习
目录Ribbon使用负载均衡代码示例注册中心Provider接口实现Consumer添加依赖测试Ribbon使用 Ribbon是管理Http和tcp服务客户端的负载均衡器,Ribbo
这里是Eureka作为服务注册中心,为OpenFeign提供服务端信息的获取,比如说服务的IP地址和端口,使用前面搭建好的项目(eureka-server)。
在idea中新建两个项目运行主类,选择前面创建好的项目(eureka-provider)。
设置不同运行主类,使用不同端口号,然后启动三个不同端口号的provider。
调用不同的服务端,会返回对应服务端的接口。
@RestController
@RequestMapping("/api")
public class PoroviderController {
@Value("${server.port}")
private String serverPort;
@PostMapping("/sayHello")
public String sayHello(String name) {
return "我是服务端" + serverPort + ",你好" + name;
}
}
新建一个spring-boot工程,取名为consumer-ribbon,在pom文件引入ribbon需要的依赖。
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-netflix-ribbon</artifactId>
</dependency>
配置端口、注册中心等
server:
port: 8091
servlet:
context-path: /ribbon
eureka:
client:
service-url:
defaultZone: http://localhost:8761/eureka/
instance:
status-page-url-path: ${server.servlet.context-path}/info
health-check-url-path: ${server.servlet.context-path}/health
spring:
application:
name: consumer-ribbon
@Configuration
public class RestTemplateConfig {
@Bean
@LoadBalanced
public RestTemplate restTemplate(){
return new RestTemplate();
}
}
yml配置负载均衡策略
# 配置的方式设置Ribbon的负载均衡策略
EUREKA-PROVIDER: # 设置服务提供方的应用名称
ribbon:
NFloadBalancerRuleClassName: com.netflix.loadbalancer.RandomRule # 策略类(全路径名)
代码方式配置负载均衡策略
@Configuration
public class RibbonConfig {
@Bean
public IRule iRule(){
return new RandomRule();
}
}
@SpringBootApplication
@EnableEurekaClient
@RibbonClient(name = "consumer-ribbon", configuration = RibbonConfig.class)
public class ConsumerRibbonApplication {
public static void main(String[] args) {
SpringApplication.run(ConsumerRibbonApplication.class, args);
}
}
客户端调用实现
@RestController
@RequestMapping("/api")
public class ConsumerRibbonController {
@Resource
private RestTemplate restTemplate;
@PostMapping("/getServerInfo")
public String getServerInfo(){
MultiValueMap<String, String> body = new LinkedMultiValueMap<>();
body.add("name", "consumer8081");
ResponseEntity<String> responseEntity = restTemplate.postForEntity("http://EUREKA-PROVIDER/provider/api/sayHello", body, String.class);
return responseEntity.getBody();
}
}
多次请求的服务端,端口随机变化,证明配置成功。
到此这篇关于SpringCloud笔记(Hoxton)Netflix之Ribbon负载均衡示例代码的文章就介绍到这了,更多相关SpringCloud Ribbon负载均衡内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!
--结束END--
本文标题: SpringCloud笔记(Hoxton)Netflix之Ribbon负载均衡示例代码
本文链接: https://lsjlt.com/news/150351.html(转载时请注明来源链接)
有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341
2024-03-01
2024-03-01
2024-03-01
2024-02-29
2024-02-29
2024-02-29
2024-02-29
2024-02-29
2024-02-29
2024-02-29
回答
回答
回答
回答
回答
回答
回答
回答
回答
回答
0