JavaのバージョンB2B2Cのソーシャル電気の供給スプリングクラウド分散マイクロサービス(c)のサービスコンシューマ(ふり)

約装う
装うそれが簡単にHTTPクライアントを書くことになり、宣言型の擬似HTTPクライアントです。装うを使用して、あなただけがインターフェイスや注釈を作成する必要があります。それは装うJAX-RS注釈やメモをプラグイン可能な注釈機能を使用することができました。プラグ可能なエンコーダおよびデコーダをふり。デフォルトの統合されたリボン、ユーレカと組み合わせて、負荷分散のデフォルトの実装を装います。

要するに:

装うは、アノテーションベースのインターフェイス使用して
統合されたリボンを装う
、第二の仕事の準備
、プロジェクトを過ごすユーレカ・サーバを起動し、ポート8761を継続するために、サービス-HI開始二回、ポートは8762、8773です。

第三に、装うサービスを作成し
、そのポンポン依存ファイルには、serice-装うという名前の新しい春ブートプロジェクトを装うが、春・クラウド・スターター・装う開始導入ユーレカは依存春・クラウド・スターター・ユーレカを開始以下のように、ウェブ依存春ブート・スターター・ウェブを開始し、コードは次のとおりです。

<?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 http://maven.apache.org/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>
    <groupId>com.forezp</groupId>
    <artifactId>service-feign</artifactId>
    <version>0.0.1-SNAPSHOT</version>
    <packaging>jar</packaging>
    <name>service-feign</name>
    <description>Demo project for Spring Boot</description>
    <parent>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-parent</artifactId>
        <version>1.5.2.RELEASE</version>
        <relativePath/> <!-- lookup parent from repository -->
    </parent>
    <properties>
        <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
        <project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
        <java.version>1.8</java.version>
    </properties>
    <dependencies>
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-eureka</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-feign</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</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>Dalston.RC1</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>
    <repositories>
        <repository>
            <id>spring-milestones</id>
            <name>Spring Milestones</name>
            <url>https://repo.spring.io/milestone</url>
            <snapshots>
                <enabled>false</enabled>
            </snapshots>
        </repository>
    </repositories>
</project>

プロジェクトのプロファイルapplication.ymlファイルでは、サービス装うと呼ばれるプログラムを指定し、ポート番号8765、登録されたサービスのアドレスはhttp:// localhostを:8761 /ユーレカ/、次のコード:

eureka:
  client:
    serviceUrl:
      defaultZone: http://localhost:8761/eureka/
server:
  port: 8765
spring:
  application:
    name: service-feign

起動クラスのServiceFeignApplicationプログラムでは、プラス@EnableFeignClientsはオープン装う機能をコメント:

@SpringBootApplication
@EnableDiscoveryClient
@EnableFeignClients
public class ServiceFeignApplication {
 
    public static void main(String[] args) {
        SpringApplication.run(ServiceFeignApplication.class, args);
    }
}

サービスコールを指定する@ FeignClientて定義されたインターフェース(「サービス名」)、装います。たとえば、次のようにコード内の「/ HI」Interfaceサービス-HIのサービスを呼び出すために、コードは次のとおりです。

/**
 * Created by fangzhipeng on 2017/4/6.
 */
@FeignClient(value = "service-hi")
public interface SchedualServiceHi {
    @RequestMapping(value = "/hi",method = RequestMethod.GET)
    String sayHiFromClientOne(@RequestParam(value = "name") String name);
}

コントローラ層のWeb層では、「/ HI」APIインタフェースへの外部被ばくは、消費者サービスへの上記で定義されたエンドSchedualServiceHiを通じて顧客を装います。コードは以下の通りであります:

@RestController
public class HiController {
 
    @Autowired
    SchedualServiceHi schedualServiceHi;
    @RequestMapping(value = "/hi",method = RequestMethod.GET)
    public String sayHi(@RequestParam String name){
        return schedualServiceHi.sayHiFromClientOne(name);
    }
}

春の雲のB2B2C、eコマース、ソーシャルプラットフォームのソースコード、ペンギンBEGを追加してください。3 4 5 6 3 II気II五十から九

おすすめ

転載: blog.csdn.net/qq_42748864/article/details/93464372