SpringCloudマイクロサービス間のサービスの呼び出し-SpringCloudマイクロサービスはFeignを使用して別のサービスを呼び出し、Feignを使用します

Feignの紹介

マイクロサービスアーキテクチャには多くのサービスインスタンスがあります。サービスとサービスの間で呼び出す方法として、SpringCloudはソリューションを提供します。

Feignは、Spring CloudおよびWebServiceクライアントのコンポーネントであり、サービス間の転送に使用されます。
Feignの詳細については、https://blog.csdn.net/wo18237095579/article/details/83343915を確認してください。

2つのサービスを作成する

2つのプロジェクトと2つのサービスを作成し、レジストリを構成してから、2つのサービスを開始すると、構成したレジストリに2つのサービス名(Daily-serverとTask-Server)が表示されます。次のように:
ここに画像の説明を挿入

Feignマイクロサービス間で呼び出す方法

ここでは、Daily-serverを介してTask-serverを呼び出します。まず、Daily-serverを構成します。詳細は次のとおりです。

  1. 依存関係を追加する

1.1:Feignの依存関係を追加する

		<dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-openfeign</artifactId>
            <scope>provided</scope>
        </dependency>

1.2ここで、SpringBootプロジェクトがSpringCloudを統合している場合、つまり、プロジェクトにSpring Bootの依存関係がある場合は、SpringCloudの依存関係を次のように追加する必要があります。

			<dependency>
				<groupId>org.springframework.cloud</groupId>
				<artifactId>spring-cloud-dependencies</artifactId>
				<version>Hoxton.SR1</version>
				<type>pom</type>
				<scope>import</scope>
			</dependency>

1.3 Spring Cloudプロジェクトを直接作成する場合、上記の1.2の手順は不要であり、SpringCloudの依存関係を直接追加します。


		<dependency>
			<groupId>org.springframework.cloud</groupId>
			<artifactId>spring-cloud-starter-hystrix</artifactId>
		</dependency>
		<dependency>
			<groupId>org.springframework.cloud</groupId>
			<artifactId>spring-cloud-starter-hystrix-dashboard</artifactId>
		</dependency>
		<dependency>
			<groupId>org.springframework.cloud</groupId>
			<artifactId>spring-cloud-starter-feign</artifactId>
		</dependency>
  1. サービススタートアップクラスにアノテーションを追加する
@EnableFeignClients

次のようにここに画像の説明を挿入
なります。3。TaskServerインターフェイスを参照するインターフェイスを作成します

package ...app.feign;

import org.springframework.cloud.openfeign.FeignClient;
import org.springframework.web.bind.annotation.GetMapping;

@FeignClient("task-server")
public interface TaskServerFeign {
    
    
    @GetMapping("/task/test")
    String getTest();
}

ここで@FeignClient( "task-server")ここで、task-serverは他のサービスの名前です
@GetMapping( "/ task / test")別のサービスのインターフェースのアドレス
String getTest();別のサービス名のインターフェース。

4.テストインターフェイスを作成し、別のサービスのインターフェイスを呼び出します

import 。。。.feign.TaskServerFeign;
import io.swagger.annotations.Api;
import io.swagger.annotations.ApiOperation;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RestController;

@RestController
@Api(tags = {
    
    "Feign测试"})
public class FeignTest {
    
    
    @Autowired
    private TaskServerFeign taskServerFeign;

    @GetMapping("/task/test1")
    public void getTest() {
    
    
        String test = taskServerFeign.getTest();
        System.out.println(test);
        System.out.println("----------this is daily_Server_test");
    }
}

@Api(tags = {"Feign test"})このアノテーションは、Swaggerテストにローカルでのみ使用されます。postmanなど、他のメソッドを使用してテスト用にこのインターフェイスを呼び出すこともできます。

@Autowired
private TaskServerFeign taskServerFeign; 3番目のステップでtask-serverを呼び出すインターフェイスを挿入します。

5.タスクサーバーで呼び出されたインターフェイスを作成します

import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RestController;

@RestController
public class FeignTest {
    
    
    @GetMapping("/task/test")
    public String getTest() {
    
    
        System.out.println("----------this is task_Server_test");
        return "this is task_Server_test";
    }
}

次のステップは、実行してテストすることです。ローカルテストは次のとおり
です。これがテスト用のテストツール
ここに画像の説明を挿入

ここに画像の説明を挿入
これがデイリーサーバー、これがタスクサーバーです。
ここに画像の説明を挿入
結果は明らかで、初心者のXiaobaiはいつでもコメントを歓迎します。0。0

おすすめ

転載: blog.csdn.net/Mou_O/article/details/104650209