Java微服務(wù)間接口調(diào)用 feign
Feign說明
Feign是一種聲明式、模板化的HTTP客戶端。在spring cloud中使用Feign,可以做到類似于普通的接口的請(qǐng)求調(diào)用,可以發(fā)現(xiàn)對(duì)應(yīng)的服務(wù)的接口,進(jìn)而直接調(diào)用對(duì)應(yīng)服務(wù)中的接口。
引入依賴,啟動(dòng)類開啟客戶端
首先需要在各個(gè)微服務(wù)中引入依賴
<dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-openfeign</artifactId> </dependency>
然后在啟動(dòng)類中加入注解@EnableFeignClients ,開啟Feign客戶端。
在各自的啟動(dòng)類中添加注釋:
@EnableDiscoveryClient 和 @EnableFeignClients ,并在配置文件中添加各自的服務(wù)名,以及配置Nacos的服務(wù)地址
//服務(wù)A的啟動(dòng)類 @EnableDiscoveryClient //nacos注冊(cè) @EnableFeignClients //Feign 服務(wù)調(diào)用 @SpringBootApplication public class ApplicationA { public static void main(String[] args){ SpringApplication.run(ApplicationA.class,args); } } //服務(wù)B的啟動(dòng)類 @EnableDiscoveryClient //nacos注冊(cè) @EnableFeignClients //Feign 服務(wù)調(diào)用 @SpringBootApplication public class ApplicationB { public static void main(String[] args){ SpringApplication.run(ApplicationB.class,args); } }
application.properties
服務(wù)A配置 # 服務(wù)端口 server.port=8001 # 服務(wù)名 spring.application.name=serviceA # nacos服務(wù)地址 spring.cloud.nacos.discovery.server-addr=127.0.0.1:8848 --------------------------服務(wù)B配置------------------------------- # 服務(wù)端口 server.port=8003 # 服務(wù)名 spring.application.name=serviceB # nacos服務(wù)地址 spring.cloud.nacos.discovery.server-addr=127.0.0.1:8848
3.在微服務(wù)A中創(chuàng)建client包和接口
然后在當(dāng)前服務(wù)內(nèi)編寫Feign接口,接口與普通的controller層類似,只是在類上不需要寫@Controller等注解,只需要加上@Component 、 @FeignClient注解即可,下面的請(qǐng)求方法需要寫上請(qǐng)求方式(根據(jù)提供服務(wù)的接口適配)@PostMapping(“/findList”)注解。如下:
@Component @FeignClient(value = "sso", path = "/api/user", fallback = UserClientHystrix.class)//value是需要調(diào)用的服務(wù)名稱,path是sso服務(wù)內(nèi)的請(qǐng)求路徑 //value必選是服務(wù)名(就是yaml中server.name) //path是前綴(就是yaml中server.contentPath) //fallback是服務(wù)熔斷的類 public interface UserClient { /** * 獲取對(duì)象集合 * @param object * @return */ @PostMapping("/findList")//根據(jù)服務(wù)適配添加注解 Result<UserDO> findList(@CustomJSONBody Object object); } //@FeignClient注解用于指定從哪個(gè)服務(wù)中調(diào)用功能 ,名稱與被調(diào)用的服務(wù)名保持一致。
在微服務(wù)A中創(chuàng)建client包和接口
@Component @FeignClient("serviceB") public interface ServiceBClient { @PostMapping("serviceB/test") public Result test(@RequestParam String args); }
注意微服務(wù)A(調(diào)用者)中ServiceBClient接口中編寫的是微服務(wù)B中被調(diào)用的接口,參數(shù)類型方法名要一致。以下時(shí)微服務(wù)B中被調(diào)用的接口(Controller)
服務(wù)B中接口的示例 @RestController @RequestMapping("serviceB") @CrossOrigin public class VodController { @PostMapping("test") public void test(@RequestParam String args){ System.out.println(args); } }
4.在微服務(wù)A中調(diào)用服務(wù)B的接口
方法總結(jié)
在微服務(wù)A中調(diào)用服務(wù)B中的接口
1.初始化操作:添加依賴,配置等等。。。
2.創(chuàng)建Client接口,使用@GetMapping注解對(duì)被調(diào)用的微服務(wù)進(jìn)行地址映射。
3.在微服務(wù)A中調(diào)用Client接口中的方法。
注:① 接口層添加注解@FeignClient,并在注解中指明屬性value="服務(wù)提供方的實(shí)例名";
② 在方法上添加映射的URL要與服務(wù)提供方接口的URL一致;
到此這篇關(guān)于Java微服務(wù)間接口調(diào)用 feign的文章就介紹到這了,更多相關(guān)接口調(diào)用 feign內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
java實(shí)現(xiàn)的MD5摘要算法完整實(shí)例
這篇文章主要介紹了java實(shí)現(xiàn)的MD5摘要算法,結(jié)合完整實(shí)例形式分析了java實(shí)現(xiàn)md5單項(xiàng)加密的具體步驟與相關(guān)操作技巧,需要的朋友可以參考下2017-01-01java Quartz定時(shí)器任務(wù)與Spring task定時(shí)的幾種實(shí)現(xiàn)方法
本篇文章主要介紹了java Quartz定時(shí)器任務(wù)與Spring task定時(shí)的幾種實(shí)現(xiàn)方法的相關(guān)資料,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下。2017-02-02SpringBoot2+Netty+WebSocket(netty實(shí)現(xiàn)websocket支持URL參數(shù))問題記錄
Netty?是一個(gè)利用?Java?的高級(jí)網(wǎng)絡(luò)的能力,隱藏其背后的復(fù)雜性而提供一個(gè)易于使用的?API?的客戶端/服務(wù)器框架,這篇文章主要介紹了SpringBoot2+Netty+WebSocket(netty實(shí)現(xiàn)websocket,支持URL參數(shù)),需要的朋友可以參考下2023-12-12