一般情况下,服务提供者也不会是单机版,应该也是个集群(参考之前的Eureka原理图),下面我们先来搭建下服务提供者的集群,然后再做负载均衡调用。
第1步:创建Module
我们参考之前的cloud-provider-payment8001子模块的创建,再创建个名为cloud-provider-payment8002的子模块。
第2步:改pom
复制8001的pom.xml中的依赖,我们该子模块的pom.xml如下:

程序员导航
优网导航旗下整合全网优质开发资源,一站式IT编程学习与工具大全网站
mscloud com.panziye.springcloud 1.0-SNAPSHOT 4.0.0 cloud-provider-payment8002 org.springframework.cloud spring-cloud-starter-netflix-eureka-client com.panziye.springcloud cloud-api-commons ${project.version} org.springframework.boot spring-boot-starter-web org.springframework.boot spring-boot-starter-actuator org.mybatis.spring.boot mybatis-spring-boot-starter com.alibaba druid-spring-boot-starter 1.2.5 mysql mysql-connector-java org.springframework.boot spring-boot-starter-jdbc org.springframework.boot spring-boot-devtools runtime true org.projectlombok lombok true org.springframework.boot spring-boot-starter-test test
第3步:写yml
在resources下新建application.yml,复制8001的yml,稍作修改,如下:
server:
port: 8002
spring:
application:
name: cloud-payment-service
datasource:
type: com.alibaba.druid.pool.DruidDataSource
driver-class-name: com.mysql.cj.jdbc.Driver
url: jdbc:mysql://localhost:3306/dbcloud?serverTimezone=UTC&characterEncoding=utf8&useUnicode=true&useSSL=false
username: root
password: 123456
mybatis:
mapperLocations: classpath:mapper/*.xml
type-aliases-package: com.panziye.springcloud.entities
eureka:
client:
#表示是否将自己注册进eureka服务中心,默认true
register-with-eureka: true
#表示是否从EurekaServer抓取已有注册信息,默认true。单节点无所谓,集群必须设置true才能配合ribbon使用负载均衡
fetch-registry: true
service-url: #指向eureka集群
defaultZone: http://eureka7001.com:7001/eureka,http://eureka7002.com:7002/eureka,http://eureka7003.com:7003/eureka
[v_blue]注意:只修改了端口为8002[/v_blue]
第4步:主启动类
在com.panziye.springcloud包下新建名为PaymentMain8002主启动类,如下:
package com.panziye.springcloud; import org.springframework.boot.SpringApplication; import org.springframework.boot.autoconfigure.SpringBootApplication; import org.springframework.cloud.netflix.eureka.EnableEurekaClient; @SpringBootApplication @EnableEurekaClient public class PaymentMain8002 { public static void main(String[] args) { SpringApplication.run(PaymentMain8002.class,args); } }
第5步:业务类
复制8001的controller、service、dao、mapper文件到8002项目对应目录下。

AI 工具导航
优网导航旗下AI工具导航,精选全球千款优质 AI 工具集
第6步:修改PaymentController
为了方便测试哪个模块提供了服务,我们修改下8001和8002中的PaymentController,添加上端口的打印。
1)新增代码如下:
//springframework包下@Value获取application.yml中的配置
@Value("${server.port}")
private String serverPort;
2)在查询操作成功是修改打印代码如下:
return new CommonResult(200,"查询数据库成功,serverPort: "+serverPort,payment);
第7步:测试
我们先启动3个注册中心(7001,7002,7003),再启动两个支付模块(8001,8002),最后启动订单模块(80),我们发现:
1)访问3个注册中心,发现支付模块有两个服务注册进去了(8001和8002)

2)我们多次访问get方法,始终调用的端口都是8001,表明始终调的是8001模块,原因是因为我们在cloud-consumer-order80中的OrderController将请求URL写死为http://localhost:8001

第8步:实现负载均衡
1)我们修改cloud-consumer-order80中的OrderController中的请求URL为服务在Eureka Server的应用名称,即:CLOUD-PAYMENT-SERVICE,之后我们服务调用只认应用名称,具体修改如下:
public static final String PAYMENT_URL = "http://CLOUD-PAYMENT-SERVICE";
2)重启后测试,再次访问,发现报错

3)解决:使用@LoadBalanced注解赋予RestTemplate负载均衡的能力
我们在cloud-consumer-order80中的ApplicationContextCofig类中,添加注解,修改如下:
package com.panziye.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 ApplicationContextCofig {
/**
* 配置RestTemplate
* @return
*/
@Bean
@LoadBalanced
public RestTemplate getRestTemplate(){
return new RestTemplate();
}
}
4)再次重启测试,发现8001和8002循环交替出现

[v_blue]提前说下Ribbon的负载均衡功能,默认情况下采用轮询策略,当然还有其他策略,后面在具体说。当Ribbon和Eureka整合后消费者模块可以直接通过微服务名称进行调用,而不用再关心地址和端口号,且该服务还有负载均衡功能。[/v_blue]

免费在线工具导航
优网导航旗下整合全网优质免费、免注册的在线工具导航大全



