摘要:不過,我們搭建好框架就是為了消費它使用它,那么這篇文章就來看看如何去消費使用我們之前搭建起來的服務(wù)吧首先本文是基于上一篇文章進行的。代碼如下啟動程序,多次訪問,瀏覽器顯示內(nèi)容為至此我們這個服務(wù)消費的框架就搭建完畢了。。。
上一篇文章主要介紹了如何搭建一個簡單的springcloud框架。不過,我們搭建好框架就是為了消費它使用它,那么這篇文章就來看看如何去消費使用我們之前搭建起來的服務(wù)吧!
首先本文是基于上一篇文章進行的。
一、Feign簡介Feign是Netflix開發(fā)的聲明式、模板化的HTTP客戶端, Feign可以幫助我們更快捷、優(yōu)雅地調(diào)用HTTP API。
二、啟動程序繼續(xù)用上一節(jié)的工程, 啟動eureka-server,端口為8080; 啟動eureka-client兩次,端口分別為8081 、8082.
三、創(chuàng)建一個feign的服務(wù)我們首先要新建一個spring-boot工程,取名為serice-feign。
這次我們要選擇三個依賴:
對應(yīng)的pom.xml文件內(nèi)容為:
4.0.0 org.springframework.boot spring-boot-starter-parent 2.1.5.RELEASE com.zhouxiaoxi eureka-feign 0.0.1-SNAPSHOT eureka-feign Demo project for Spring Boot 1.8 Greenwich.SR1 org.springframework.boot spring-boot-starter-web org.springframework.cloud spring-cloud-starter-netflix-eureka-client org.springframework.cloud spring-cloud-starter-openfeign org.springframework.boot spring-boot-starter-test test org.springframework.cloud spring-cloud-dependencies ${spring-cloud.version} pom import org.springframework.boot spring-boot-maven-plugin
接下來我們就需要配置application.yml文件了:
server: #端口號 port: 8083 spring: application: #端口名稱 name: eureka-feign eureka: client: serviceUrl: #服務(wù)注冊地址 defaultZone: http://localhost:8080/eureka/
在程序的啟動類EurekaFeignApplication,加上@EnableFeignClients注解開啟Feign的功能:
package com.zhouxiaoxi.eurekafeign; import org.springframework.boot.SpringApplication; import org.springframework.boot.autoconfigure.SpringBootApplication; import org.springframework.cloud.netflix.eureka.EnableEurekaClient; import org.springframework.cloud.openfeign.EnableFeignClients; @SpringBootApplication @EnableEurekaClient @EnableFeignClients public class EurekaFeignApplication { public static void main(String[] args) { SpringApplication.run(EurekaFeignApplication.class, args); } }
現(xiàn)在我們需要定義一個feign接口,通過@FeignClient(“服務(wù)名”)注解來指定調(diào)用哪個服務(wù)。
比如在下面的代碼中調(diào)用了eureka-client服務(wù)的“/hello”接口,代碼如下:
package com.zhouxiaoxi.eurekafeign.service; import org.springframework.cloud.openfeign.FeignClient; import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.RequestMethod; import org.springframework.web.bind.annotation.RequestParam; @FeignClient(value = "eureka-client") public interface SchedualServiceHello { @RequestMapping(value = "/hello",method = RequestMethod.GET) String sayHiFromClientOne(@RequestParam(value = "name") String name); }
在Web層的controller層,對外暴露一個”/hello”的API接口,通過上面定義的Feign客戶端SchedualServiceHello 來消費服務(wù)。代碼如下:
package com.zhouxiaoxi.eurekafeign.controller; import com.zhouxiaoxi.eurekafeign.service.SchedualServiceHello; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.web.bind.annotation.GetMapping; import org.springframework.web.bind.annotation.RequestParam; import org.springframework.web.bind.annotation.RestController; @RestController public class HelloController { @Autowired SchedualServiceHello schedualServiceHello; @GetMapping(value = "/hello") public String sayHi(@RequestParam String name) { return schedualServiceHello.sayHiFromClientOne( name ); } }
啟動程序,多次訪問http://localhost:8083/hello?name=feign,瀏覽器顯示內(nèi)容為:
hello feign ,i am from port:8081
hello feign ,i am from port:8082
至此我們這個服務(wù)消費的框架就搭建完畢了。。。
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/74585.html
摘要:它就是史上最簡單的教程第三篇服務(wù)消費者后端掘金上一篇文章,講述了通過去消費服務(wù),這篇文章主要講述通過去消費服務(wù)。概覽和架構(gòu)設(shè)計掘金技術(shù)征文后端掘金是基于的一整套實現(xiàn)微服務(wù)的框架。 Spring Boot 配置文件 – 在坑中實踐 - 后端 - 掘金作者:泥瓦匠鏈接:Spring Boot 配置文件 – 在坑中實踐版權(quán)歸作者所有,轉(zhuǎn)載請注明出處本文提綱一、自動配置二、自定義屬性三、ran...
摘要:接下來繼續(xù)介紹三種架構(gòu)模式,分別是查詢分離模式微服務(wù)模式多級緩存模式。分布式應(yīng)用程序可以基于實現(xiàn)諸如數(shù)據(jù)發(fā)布訂閱負(fù)載均衡命名服務(wù)分布式協(xié)調(diào)通知集群管理選舉分布式鎖和分布式隊列等功能。 SpringCloud 分布式配置 SpringCloud 分布式配置 史上最簡單的 SpringCloud 教程 | 第九篇: 服務(wù)鏈路追蹤 (Spring Cloud Sleuth) 史上最簡單的 S...
摘要:集群系統(tǒng)中的單個計算機通常稱為節(jié)點,通常通過局域網(wǎng)連接,但也有其它的可能連接方式。這樣就高興了,可以專心寫自己的,前端就專門交由小周負(fù)責(zé)了。于是,小周和就變成了協(xié)作開發(fā)。都是為了項目正常運行以及迭代。 一、前言 只有光頭才能變強 認(rèn)識我的朋友可能都知道我這陣子去實習(xí)啦,去的公司說是用SpringCloud(但我覺得使用的力度并不大啊~~)... 所以,這篇主要來講講SpringClou...
摘要:集群系統(tǒng)中的單個計算機通常稱為節(jié)點,通常通過局域網(wǎng)連接,但也有其它的可能連接方式。這樣就高興了,可以專心寫自己的,前端就專門交由小周負(fù)責(zé)了。于是,小周和就變成了協(xié)作開發(fā)。都是為了項目正常運行以及迭代。 一、前言 只有光頭才能變強 認(rèn)識我的朋友可能都知道我這陣子去實習(xí)啦,去的公司說是用SpringCloud(但我覺得使用的力度并不大啊~~)... 所以,這篇主要來講講SpringClou...
閱讀 2646·2021-10-14 09:47
閱讀 4938·2021-09-22 15:52
閱讀 3361·2019-08-30 15:53
閱讀 1458·2019-08-30 15:44
閱讀 688·2019-08-29 16:41
閱讀 1657·2019-08-29 16:28
閱讀 447·2019-08-29 15:23
閱讀 1628·2019-08-26 12:20