Article catalogue
- What's Feign
- ( Ribbon+RestTemplate) Vs Feign
- Feign integration
- test
- Source code
data:image/s3,"s3://crabby-images/c4f87/c4f872ab56d7b24b876fd2cdcec76a0e14069cd1" alt=""
What's Feign
Feign is a declarative and templated HTTP client developed by Netflix, inspired by Retrofit and JAXRS 2.0 and WebSocket.
Feign can help us call HTTP API more conveniently and gracefully
In Spring Cloud, using Feign is very simple - just create an interface and add annotations on it.
Feign supports a variety of annotations, such as feign's own annotations or JAX RS annotation, etc. Spring Cloud has enhanced feign to support spring MVC annotations
In addition, Ribbon and Eureka are integrated to make Feign more convenient to use
( Ribbon+RestTemplate) Vs Feign
In the previous way, we use Ribbon+RestTemplate to invoke micro services. What's the disadvantage?
ResponseEntity<PayInfo> responseEntity = restTemplate.getForEntity(PAY_URI + orderInfo.getProductNo(), PayInfo.class); #Ribbon call @Bean @LoadBalanced public RestTemplate restTemplate() { return new RestTemplate(); }
Two disadvantages:
- If the constructed URL is very complex, passing parameters is a problem.
- At the same time, when the business is more complex, it is difficult to understand.
Feign integration
Construction of artist feign API sub module
Adopt the routine commonly used in development to define an artist feign API project, which is used to manage the interface with other services separately. Modules like DAO and COMMON
Step1 do not rely on
<dependency> <groupId>org.springframework.cloudgroupId> <artifactId>spring-cloud-starter-openfeignartifactId> dependency>
Step 2 modify packaging method
<build> <plugins> <plugin> <groupId>org.apache.maven.plugins</groupId> <artifactId>maven-jar-plugin</artifactId> </plugin> </plugins> </build>
The project is an ordinary jar, and there is no need to type an executable jar
Step 3 write declarative interface
@FeignClient(name = "artisan-product-center") public interface ProductCenterFeignApi { /** * Declarative interface, remote call http://artisan-product-center/selectProductInfoById/{productNo} * @param productNo * @return */ @RequestMapping("/selectProductInfoById/{productNo}") ProductInfo selectProductInfoById(@PathVariable("productNo") String productNo); }
How to write this declarative interface--------- Copy the Controller interface directly.
Call the project artist cloud feign order to build
Step1 do not rely on
<dependency> <groupId>com.artisan</groupId> <artifactId>artisan-feign-api</artifactId> <version>1.0-SNAPSHOT</version> </dependency>
The introduction of the sub module just now is equivalent to referring to feign because the dependency is passed. Here, only the sub module can be referenced.
data:image/s3,"s3://crabby-images/de804/de804592b63b02b8b3ad345b29893dbf773d8fd6" alt=""
Step 2 annotation
Open annotation and add @ EnableFeignClients
data:image/s3,"s3://crabby-images/09848/09848668ace372dff02afecbedfba1cf18bc9c85" alt=""
Step 3 call (call the remote service like calling the local mode)
data:image/s3,"s3://crabby-images/74529/7452920cf2018f8fda95ada9cdf20b72514fa2d5" alt=""
Built by service provider artist cloud feign product
Like ordinary projects, there is no need for transformation
data:image/s3,"s3://crabby-images/6b17c/6b17c1677e199e58c2042a0369436955665228d2" alt=""
test
Start two services
artisan-cloud-feign-order artisan-cloud-feign-product
Access the interface provided by the Order service
data:image/s3,"s3://crabby-images/c396d/c396d316d50505218bdc3c46e42d7bb8ae192b2c" alt=""