springcloud-Ribbon和springcloud-eureka 实现负载均衡

本文档介绍了如何配置Spring Cloud应用,使其通过Eureka注册中心进行服务发现,并利用Ribbon实现客户端负载均衡。首先,将服务注册到由三个Eureka节点组成的集群上,然后在客户端引入Spring Cloud Eureka和Spring Cloud Ribbon依赖。接着,配置客户端不注册自身,并设置Eureka服务地址。在启动类中启用Eureka Client,并创建一个负载均衡的RestTemplate。最后,在Controller中使用RestTemplate调用其他微服务,实现服务间的通信。

 

 

 

//准备工作

/**已经将名为SPRINGCLOUD-PROVIDER-DEPT的服务注册到了由

http://eureka7001.com:7001/eureka/,http://eureka7002.com:7002/eureka/,http://eureka7003.com:7003/eureka/ 三个eureka注册中心组成的集群上面了。

*/

1.导包 在客户端导入 spring-cloud-starter-ribbon、spring-cloud-starter-eureka(注意这是客户端的包)

    <!--eureka需要的包-->
    <dependency>
        <groupId>org.springframework.cloud</groupId>
        <artifactId>spring-cloud-starter-eureka</artifactId>
        <version>1.4.0.RELEASE</version>
    </dependency>
    <!--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.0.RELEASE</version>
    </dependency>

2.配置 配置客户端不在eureka中注册,以及服务注册地址

//http://eureka7001.com:7001/eureka/,http://eureka7002.com:7002/eureka/,http://eureka7003.com:7003/eureka/

//是三个注册中心的地址

 

server:
  port: 80
eureka:
  client:
    register-with-eureka: false #不在eureka中注册自己
    service-url:
         defaultZone: http://eureka7001.com:7001/eureka/,http://eureka7002.com:7002/eureka/,http://eureka7003.com:7003/eureka/

eureka: client: register-with-eureka: false #不在eureka中注册自己 service-url: defaultZone: http://eureka7001.com:7001/eureka/,http://eureka7002.com:7002/eureka/,http://eureka7003.com:7003/eureka/

3.在启动类中添加启动eureka的注解@EnableEurekaClient

4.配置能够实现负载均衡的RestTemplate

给RestTemplate 添加 @LoadBalanced注解 即可

package com.zyh.springcloud.config;

import org.springframework.cloud.client.loadbalancer.LoadBalanced;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.web.client.RestTemplate;

@Configuration
public class ConfigBean {
    //    配置负载均衡实现restTemplage
    @LoadBalanced //Ribbon
    @Bean
    public RestTemplate getRestTemplate( ){
        return new RestTemplate();

    }

}

 

5.在controller中调用

SPRINGCLOUD-PROVIDER-DEPT 是调用的服务名

@RestController
@RequestMapping("/consumer")
public class DeptConsumerController {

    @Autowired
    private  RestTemplate restTemplate;//提供多种访问远程服务接口的方法
    private final String  REST_URL_PREFIX="http://SPRINGCLOUD-PROVIDER-DEPT/";
    @PostMapping("/saveDept")
    public Boolean  saveDept( @RequestBody DeptBo deptBo){
        return restTemplate.postForObject(REST_URL_PREFIX + "/dept/addDept",deptBo,                                 Boolean.class);
    }

}

 待完善

 

 

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值