SpringCloud Ribbon負荷バランス例解析
この文章は主にSpringCloud Ribbonの負荷バランスの実例解析を紹介しています。ここでは例示的なコードを通して紹介された非常に詳細で、皆さんの学習や仕事に対して一定の参考学習価値を持っています。必要な友達は以下のように参照してください。
Spring Cloudは、Ribbonを統合し、Eurekaと組み合わせることで、クライアントの負荷バランスを実現することができます。
次の例を示します。構造は下図のようになります。
一、サーバ端
1、作成項目
開発ツール:IntelliJ IDEA 209.2.3
IDEAで新たなSprigBootプロジェクトを作成しました。名前は「cloud-server」、Spring Bootバージョンは2.10を選択して、Dependencies(依存)を選択するインターフェースでSpring Cloud Discovertをチェックします。
Eureka Serverは、作成後のpom.xmlプロファイルにSpringCloudの最新の安定バージョンの依存性を自動的に追加し、現在はGreen wich.SR 3です。
pom.xmlの内容は以下の通りです。
コメントを追加します。
1、作成項目
IDEAでは、「cloud-provider」という名前のほかに、新しいSpring Bootプロジェクトを作成します。他のステップは上のサーバ端末と同じです。
2、配置を変更するappication.yml
コメントを追加します。
クラスを起動時にコンソール入力を読み取り、どのポートでサーバーを起動するかを決定させる。
テスト用のコントローラ方法を追加します。
1、作成項目
IDEAでは、「cloud-invoker」という名前のほかに、新しいSprigBootプロジェクトを作成します。他のステップは上のサーバ端末と同じです。
2、配置を変更するappication.yml
コメントを追加します。
方式一:コードの使用
(1)カスタム負荷規則類MyRule.javaを新規作成します。
Ribbonの負荷イコライザインターフェースはサーバの操作を定義しています。主にサーバの選択を行うためです。
ILoadBalancerを呼び出すgetAll Servers方法は、すべてのサーバに戻ります。ここでは最初のサーバだけに戻ります。
負荷イコライザはPing機構を提供しています。Pingサーバに時間ごとに行ってサーバが生存しているかどうかを判断します。
この仕事はIPingインターフェースの実現類が担当する。
方式の一つの二つの構成類を注釈して、appication.ymlの一番後ろに次の構成を追加します。
1、サーバ端を起動します。
2、二つのサービスプロバイダを起動し、コンソールにそれぞれ8080と8081を入力して起動する。
3、サービス利用者を起動する。
4、ブラウザアクセスhttp://localhost:9000/router、何度もページを更新し、結果はすべて次の通りである。
http://localhost:8081/
サービス運用者項目IDEAコンソールタイミング出力:
Spring Cloudは、Ribbonを統合し、Eurekaと組み合わせることで、クライアントの負荷バランスを実現することができます。
次の例を示します。構造は下図のようになります。
一、サーバ端
1、作成項目
開発ツール:IntelliJ IDEA 209.2.3
IDEAで新たなSprigBootプロジェクトを作成しました。名前は「cloud-server」、Spring Bootバージョンは2.10を選択して、Dependencies(依存)を選択するインターフェースでSpring Cloud Discovertをチェックします。
Eureka Serverは、作成後のpom.xmlプロファイルにSpringCloudの最新の安定バージョンの依存性を自動的に追加し、現在はGreen wich.SR 3です。
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、配置を変更するappication.yml
server:
port: 8761
eureka:
client:
register-with-eureka: false
fetch-registry: false
3、起動クラスコードCloudServerApple.javaを修正するコメントを追加します。
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);
}
}
二、サービスプロバイダ1、作成項目
IDEAでは、「cloud-provider」という名前のほかに、新しいSpring Bootプロジェクトを作成します。他のステップは上のサーバ端末と同じです。
2、配置を変更するappication.yml
spring:
application:
name: cloud-provider
eureka:
instance:
hostname: localhost
client:
serviceUrl:
defaultZone: http://localhost:8761/eureka/
3、スタートクラスのコードCloudProvider Appplication.javaを修正するコメントを追加します。
クラスを起動時にコンソール入力を読み取り、どのポートでサーバーを起動するかを決定させる。
テスト用のコントローラ方法を追加します。
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();
}
}
三、サービス利用者1、作成項目
IDEAでは、「cloud-invoker」という名前のほかに、新しいSprigBootプロジェクトを作成します。他のステップは上のサーバ端末と同じです。
2、配置を変更するappication.yml
server:
port: 9000
spring:
application:
name: cloud-invoker
eureka:
instance:
hostname: localhost
client:
serviceUrl:
defaultZone: http://localhost:8761/eureka/
3、起動クラスコードCloudInvokerAplication.javaを修正するコメントを追加します。
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、Ribboonを配置するには2つの方法があります。コードを使って、配置ファイルを使います。方式一:コードの使用
(1)カスタム負荷規則類MyRule.javaを新規作成します。
Ribbonの負荷イコライザインターフェースはサーバの操作を定義しています。主にサーバの選択を行うためです。
ILoadBalancerを呼び出すgetAll Servers方法は、すべてのサーバに戻ります。ここでは最初のサーバだけに戻ります。
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.javaを新規に作成する負荷イコライザは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 {
}
方式二:プロファイルを使う方式の一つの二つの構成類を注釈して、appication.ymlの一番後ろに次の構成を追加します。
cloud-provider:
ribbon:
NFLoadBalancerRuleClassName: com.example.cloudinvoker.MyRule
NFLoadBalancerPingClassName: com.example.cloudinvoker.MyPing
listOfServers: http://localhost:8080/を します。http://localhost:8081/
5、コントローラInvoker Controller.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
以上が本文の全部です。皆さんの勉強に役に立つように、私たちを応援してください。