1. 程式人生 > >Spring Cloud入門:服務消費(Spring Cloud Ribbon)

Spring Cloud入門:服務消費(Spring Cloud Ribbon)

文章例項使用的Spring Cloud版本為Finchley.SR1,Spring Boot版本為2.0.4

1 Spring Cloud Ribbon

Spring Cloud Ribbon是一個基於HTTP和TCP的客戶端負載均衡工具,它基於Netflix Ribbon實現。通過Spring Cloud的封裝,可以讓我們輕鬆地將面向服務的REST模板請求自動轉換成客戶端負載均衡的服務呼叫。
RestTemplate是Spring實現的一個對HTTP請求封裝處理的類,它簡化了與HTTP伺服器的通訊,並遵循了RESTful原則。在Spring Cloud應用中,它可以結合Ribbon,建立一個具有負載均衡作用的RestTemplate,用於服務消費。

2 例項

2.1 建立Spring Boot應用,引入相關依賴

 <parent>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-parent</artifactId>
        <version>2.0.4.RELEASE</version>
        <relativePath/>
    </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.boot</groupId>
            <artifactId>spring-boot-starter</artifactId>
        </dependency>

        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-test</artifactId>
            <scope>test</scope>
        </dependency>

        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>

        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-actuator</artifactId>
        </dependency>

        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
        </dependency>

        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-netflix-hystrix</artifactId>
        </dependency>
    </dependencies>

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

2.2 application.properties指定註冊中心

spring.application.name=ribbon-consumer
server.port=3001

#專案資訊
info.name=${spring.application.name}
info.server.ip-address=${spring.cloud.client.ip-address}
info.server.port=${server.port}

#例項預設通過使用域名形式註冊到註冊中心:false
eureka.instance.prefer-ip-address=true

#例項名
eureka.instance.instance-id=${spring.cloud.client.ip-address}:${server.port}

#註冊中心地址
eureka.client.serviceUrl.defaultZone=http://peer2:1002/eureka/,http://peer2:1003/eureka/

2.3 建立一個具有負載均衡作用的RestTemplate

@SpringCloudApplication
public class RibbonConsumerApplication {

	@Bean
	@LoadBalanced
	public RestTemplate restTemplate(){
		return new RestTemplate();
	}

	public static void main(String[] args) {
		SpringApplication.run(RibbonConsumerApplication.class, args);
	}
}

2.4 使用RestTemplate進行服務的呼叫

@RestController
public class ConsumerController {

    @Autowired
    private RestTemplate restTemplate;

    @GetMapping("/ribbon-consumer/hello")
    public String comsume(){
    	//呼叫EUREKA-CLIENT提供的服務
        return restTemplate.getForObject("http://EUREKA-CLIENT/hello",String.class);
    }
}

2.4 啟動應用

訪問http://localhost:3001/ribbon-consumer/hello,可以到應用成功呼叫了EUREKA-CLIENT的服務。