SpringCloud Ribbon 부하 균형 실례 분석
Spring Cloud 는 Ribbon 을 통합 하여 Eureka 와 결합 하여 클 라 이언 트 의 부하 균형 을 실현 할 수 있 습 니 다.
다음은 하나의 예 를 실현 하고 구조 아래 그림 에서 보 여 준다.
서버 쪽
1.프로젝트 생 성
개발 도구:IntelliJ IDEA 2019.2.3
IDEA 에서 새로운 SpringBoot 프로젝트 를 만 듭 니 다.이름 은"cloud-server"입 니 다.SpringBoot 버 전 은 2.1.10 을 선택 하고 Dependencies(의존)를 선택 한 인터페이스 에서 Spring Cloud Discovert->를 선택 하 십시오.
Eureka Server,생 성 완료 후 pom.xml 프로필 은 SpringCloud 의 최신 안정 적 인 버 전 의존 도 를 자동 으로 추가 합 니 다.현재 Greenwich.SR3 입 니 다.
pom.xml 전체 내용 은 다음 과 같 습 니 다.
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>2.1.10.RELEASE</version>
<relativePath/> <!-- lookup parent from repository -->
</parent>
<groupId>com.example</groupId>
<artifactId>cloud-server</artifactId>
<version>0.0.1-SNAPSHOT</version>
<name>cloud-server</name>
<description>Demo project for Spring Boot</description>
<properties>
<java.version>1.8</java.version>
<spring-cloud.version>Greenwich.SR3</spring-cloud.version>
</properties>
<dependencies>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-netflix-eureka-server</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
<scope>test</scope>
</dependency>
</dependencies>
<dependencyManagement>
<dependencies>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-dependencies</artifactId>
<version>${spring-cloud.version}</version>
<type>pom</type>
<scope>import</scope>
</dependency>
</dependencies>
</dependencyManagement>
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
</plugin>
</plugins>
</build>
</project>
2.설정 수정 application.yml
server:
port: 8761
eureka:
client:
register-with-eureka: false
fetch-registry: false
3.시작 코드 클 라 우 드 서버 응용 프로그램.자바 수정주석 추가@EnableEurekaServer
package com.example.cloudserver;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.netflix.eureka.server.EnableEurekaServer;
@SpringBootApplication
@EnableEurekaServer
public class CloudServerApplication {
public static void main(String[] args) {
SpringApplication.run(CloudServerApplication.class, args);
}
}
2.서비스 제공 자1.프로젝트 생 성
IDEA 에서 새로운 SpringBoot 프로젝트 를 만 듭 니 다.이름 이'cloud-provider'인 것 을 제외 하고 다른 절 차 는 위 에서 서버 를 만 드 는 것 과 같 습 니 다.
2.설정 수정 application.yml
spring:
application:
name: cloud-provider
eureka:
instance:
hostname: localhost
client:
serviceUrl:
defaultZone: http://localhost:8761/eureka/
3.시작 클래스 코드 CloudProvider Application.java 수정주석 추가@EnableEurekaClient;
클래스 가 시작 할 때 콘 솔 입력 을 읽 고 어느 포트 로 서버 를 시작 할 지 결정 합 니 다.
테스트 용 컨트롤 러 방법 을 추가 합 니 다.
package com.example.cloudprovider;
//import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.boot.builder.SpringApplicationBuilder;
import org.springframework.cloud.netflix.eureka.EnableEurekaClient;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
import javax.servlet.http.HttpServletRequest;
import java.util.Scanner;
@SpringBootApplication
@EnableEurekaClient
@RestController
public class CloudProviderApplication {
public static void main(String[] args) {
//SpringApplication.run(CloudProviderApplication.class, args);
Scanner scan = new Scanner(System.in);
String port = scan.nextLine();
new SpringApplicationBuilder(CloudProviderApplication.class).properties("server.port=" + port).run(args);
}
@RequestMapping("/")
public String index(HttpServletRequest request) {
return request.getRequestURL().toString();
}
}
3.서비스 호출 자1.프로젝트 생 성
IDEA 에서 새로운 SpringBoot 프로젝트 를 만 듭 니 다.이름 이'cloud-invoker'인 것 을 제외 하고 다른 절 차 는 위 에서 서버 를 만 드 는 것 과 같 습 니 다.
2.설정 수정 application.yml
server:
port: 9000
spring:
application:
name: cloud-invoker
eureka:
instance:
hostname: localhost
client:
serviceUrl:
defaultZone: http://localhost:8761/eureka/
3.시작 클래스 코드 CloudInvokerapplication.java 수정주석 추가@EnableDiscoveryClient.
package com.example.cloudinvoker;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.client.discovery.EnableDiscoveryClient;
@SpringBootApplication
@EnableDiscoveryClient
public class CloudInvokerApplication {
public static void main(String[] args) {
SpringApplication.run(CloudInvokerApplication.class, args);
}
}
4.Ribbon 을 설정 하 는 방법 은 두 가지 가 있 습 니 다.코드 를 사용 하고 프로필 을 사용 합 니 다.방식 1:코드 사용
(1)사용자 정의 부하 규칙 클래스 MyRule.java 를 새로 만 듭 니 다.
Ribbon 의 부하 균형 기 인 터 페 이 스 는 서버 의 조작 을 정의 하 는데 주로 서버 선택 에 사용 된다.
ILoadBalancer 의 getAllServers 방법 을 호출 하면 모든 서버 를 되 돌려 줍 니 다.여 기 는 첫 번 째 서버 만 되 돌려 줍 니 다.
package com.example.cloudinvoker;
import com.netflix.loadbalancer.ILoadBalancer;
import com.netflix.loadbalancer.IRule;
import com.netflix.loadbalancer.Server;
import java.util.List;
public class MyRule implements IRule {
private ILoadBalancer iLoadBalancer;
@Override
public Server choose(Object o) {
List<Server> servers = iLoadBalancer.getAllServers();
System.out.println(" , :");
for(Server s: servers){
System.out.println(" " + s.getHostPort());
}
return servers.get(0);
}
@Override
public void setLoadBalancer(ILoadBalancer iLoadBalancer) {
this.iLoadBalancer = iLoadBalancer;
}
@Override
public ILoadBalancer getLoadBalancer() {
return this.iLoadBalancer;
}
}
(2)Ping 클래스 MyPing.자바 새로 만 들 기부하 이퀄 라이저 에 서 는 Ping 체 제 를 제공 하여 일정 시간 마다 Ping 서버 에 가서 서버 의 생존 여 부 를 판단 합 니 다.
이 작업 은 IPing 인터페이스의 실현 클래스 가 맡 는 다.
package com.example.cloudinvoker;
import com.netflix.loadbalancer.IPing;
import com.netflix.loadbalancer.Server;
public class MyPing implements IPing {
@Override
public boolean isAlive(Server server) {
System.out.println(" Ping , :" + server.getHostPort() + ", :" + server.isAlive());
return true;
}
}
(3)새 설정 클래스 MyConfig.java
package com.example.cloudinvoker.config;
import com.example.cloudinvoker.MyPing;
import com.example.cloudinvoker.MyRule;
import com.netflix.loadbalancer.IPing;
import com.netflix.loadbalancer.IRule;
import org.springframework.context.annotation.Bean;
public class MyConfig {
@Bean
public IRule getRule(){
return new MyRule();
}
@Bean
public IPing getPing(){
return new MyPing();
}
}
(4)새 설정 클래스 CloudProvider Config.java
package com.example.cloudinvoker.config;
import org.springframework.cloud.netflix.ribbon.RibbonClient;
@RibbonClient(name = "cloud-provider", configuration = MyConfig.class)
public class CloudProviderConfig {
}
방식 2:프로필 사용방식 1 의 두 설정 클래스 설명 을 지우 고 application.yml 의 맨 뒤에 아래 설정 을 추가 합 니 다.
cloud-provider:
ribbon:
NFLoadBalancerRuleClassName: com.example.cloudinvoker.MyRule
NFLoadBalancerPingClassName: com.example.cloudinvoker.MyPing
listOfServers: http://localhost:8080/,http://localhost:8081/
5.컨트롤 러 InvokerController.java 추가
package com.example.cloudinvoker;
import org.springframework.cloud.client.loadbalancer.LoadBalanced;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.http.MediaType;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;
import org.springframework.web.bind.annotation.RestController;
import org.springframework.web.client.RestTemplate;
@RestController
@Configuration
public class InvokerController {
@LoadBalanced
@Bean
public RestTemplate getRestTemplate(){
return new RestTemplate();
}
@RequestMapping(value="/router", method = RequestMethod.GET,produces = MediaType.APPLICATION_JSON_VALUE)
public String router(){
RestTemplate restTemplate = getRestTemplate();
//
String json = restTemplate.getForObject("http://cloud-provider/", String.class);
return json;
}
}
테스트1.서버 쪽 을 시작 합 니 다.
2.두 서비스 제공 자 를 시작 하고 콘 솔 에 각각 8080 과 8081 을 입력 하여 시작 합 니 다.
3.서비스 호출 자 를 시작 합 니 다.
4.브 라 우 저 방문http://localhost:9000/router여러 번 페이지 를 새로 고침 한 결과:
http://localhost:8081/
서비스 호출 자 항목 IDEA 콘 솔 정시 출력:
, :
localhost:8081
localhost:8080
Ping , :localhost:8081, :true
Ping , :localhost:8080, :true
이상 이 바로 본 고의 모든 내용 입 니 다.여러분 의 학습 에 도움 이 되 고 저 희 를 많이 응원 해 주 셨 으 면 좋 겠 습 니 다.
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
thymeleaf로 HTML 페이지를 동적으로 만듭니다 (spring + gradle)지난번에는 에서 화면에 HTML을 표시했습니다. 이번에는 화면을 동적으로 움직여보고 싶기 때문에 입력한 문자를 화면에 표시시키고 싶습니다. 초보자의 비망록이므로 이상한 점 등 있으면 지적 받을 수 있으면 기쁩니다! ...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.