Spring cloud 2.0 瞭解(三) 搭建消費者

視頻:https://www.majiaxueyuan.com/

 

和生產者的流程差不多,但是需要註明調用哪一個生產者,以及配置Ribbion的負載即可。

 

1.創建maven項目

新建maven項目

通過在項目裏導入model model爲新建的mvn項目。

 

2.導入pom依賴

        <parent>
		<groupId>org.springframework.boot</groupId>
		<artifactId>spring-boot-starter-parent</artifactId>
		<version>2.0.0.RELEASE</version>
	</parent>
	<!-- 管理依賴 -->
	<dependencyManagement>
		<dependencies>
			<dependency>
				<groupId>org.springframework.cloud</groupId>
				<artifactId>spring-cloud-dependencies</artifactId>
				<version>Finchley.M7</version>
				<type>pom</type>
				<scope>import</scope>
			</dependency>
		</dependencies>
	</dependencyManagement>
	<dependencies>
		<!-- SpringBoot整合Web組件 -->
		<dependency>
			<groupId>org.springframework.boot</groupId>
			<artifactId>spring-boot-starter-web</artifactId>
		</dependency>
		<!-- SpringBoot整合eureka客戶端 -->
		<dependency>
			<groupId>org.springframework.cloud</groupId>
			<artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
		</dependency>

	</dependencies>
	<!-- 注意: 這裏必須要添加, 否者各種依賴有問題 -->
	<repositories>
		<repository>
			<id>spring-milestones</id>
			<name>Spring Milestones</name>
			<url>https://repo.spring.io/libs-milestone</url>
			<snapshots>
				<enabled>false</enabled>
			</snapshots>
		</repository>
	</repositories>

 

3.創建application.yml配置

和生產者的配置幾乎一致。只是將消費端起名爲order 訂單服務。

###服務啓動端口號
server:
  port: 8001
###服務名稱(服務註冊到eureka名稱)  
spring:
    application:
        name: appname-order
###服務註冊到eureka地址
eureka:
  client:
    service-url:
           defaultZone: http://localhost:8100/eureka          
###因爲該應用爲註冊中心,不會註冊自己
    register-with-eureka: true
###是否需要從eureka上獲取註冊信息
    fetch-registry: true

 

4.編寫啓動類

和生產者不一樣的是需要配置一個可以請求客戶端的實例對象。

 

@SpringBootApplication
@EnableEurekaClient
public class AppOrder {

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


	@Bean
	@LoadBalanced  //配置客戶端負載
	RestTemplate restTemplate() {
		return new RestTemplate();
	}
}

 

編寫控制層模擬實際業務調用情況

@RestController
public class OrderController {

	@Autowired   //實例化調用客戶端請求對象
	private RestTemplate restTemplate;

	@RequestMapping("/getorder")
	public String getOrder() {
		// order 使用rpc 遠程調用技術 調用 會員服務
		String memberUrl = "http://appname-member/getMember";
		String result = restTemplate.getForObject(memberUrl, String.class);
		System.out.println("order訂單服務調用會員服務,result:" + result);
		return result;
	}
}

(關於 resttemplate 可以瞭解下:https://www.cnblogs.com/f-anything/p/10084215.html

 

5.啓動eureka註冊中心

6.啓動生產者

 

7.啓動消費者,查看註冊情況

(這裏報錯的地方應該是丟失大量心跳處罰的自我保護機制,按照視頻的說法是不需要關閉這個機制)

 

8.通過消費者獲取到生產者提供的數據

 

這個時候可以通過調用order的接口,走controller裏的方法獲取member服務的數據。(截圖的端口和代碼端口不符合,請按照實際暴露的接口進行使用)

1.這是直接調用生產者的接口

2.通過order接口調用生產者接口

以上。

 

 

 

 

 

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章