关键词:
环境
- spring cloud Edgware.SR6
- jdk 7
- sts 4.6.0
- mysql 5.7
背景
通过声明式客户端 openfeign 进行支付微服务的访问。
搭建步骤
只需要修改支付服务调用层,增加依赖就可以了。
支付服务调用层
只需要定义接口,不需要进行实现。
package jiangbo.springcloud.dao;
import org.springframework.cloud.netflix.feign.FeignClient;
import org.springframework.web.bind.annotation.PostMapping;
import jiangbo.springcloud.dao.dto.PaymentRequest;
import jiangbo.springcloud.dao.dto.PaymentResponse;
@FeignClient("payment")
public interface PaymentDao {
@PostMapping("/payment")
PaymentResponse payment(PaymentRequest paymentRequest);
}
启动类
package jiangbo.springcloud;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.netflix.eureka.EnableEurekaClient;
import org.springframework.cloud.netflix.feign.EnableFeignClients;
@SpringBootApplication
@EnableEurekaClient
@EnableFeignClients
public class JiangBoApplication {
public static void main(String[] args) {
SpringApplication.run(JiangBoApplication.class, args);
}
}
pom.xml
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<parent>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-parent</artifactId>
<version>Edgware.SR6</version>
</parent>
<groupId>jiangbo.springcloud</groupId>
<artifactId>12spring-cloud-order</artifactId>
<version>1.0.0</version>
<packaging>jar</packaging>
<properties>
<java.version>1.7</java.version>
</properties>
<dependencies>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-openfeign</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-jdbc</artifactId>
</dependency>
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<scope>runtime</scope>
</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-devtools</artifactId>
<scope>provided</scope>
</dependency>
</dependencies>
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
</plugin>
</plugins>
</build>
</project>
验证
使用 curl 命令访问订单微服务,查看返回,如果返回的订单已支付,则表示通过声明式客户端访问成功。
curl -H "Content-Type: application/json" -X POST --data ‘{"name":"jiangbo11","amount":"8.99"}‘, http://localhost:4410/order/payment
{"id":12,"name":"jiangbo11","amount":"8.99","status":"PAID","createTime":1587304461000,"updateTime":1587304462000}
默认也是具有负载均衡的。
springcloud第七篇|声明式服务调用feign
本文是SpringCloud专栏的第七篇文章,了解前六篇文章内容有助于更好的理解本文:SpringCloud第一篇|SpringCloud前言及其常用组件介绍概览SpringCloud第二篇|使用并认识Eureka注册中心SpringCloud第三篇|搭建高可用Eureka注册中心SpringCloud第四... 查看详情
springcloud——feign声明式服务调用(代码片段)
什么是FeignFeign是SpringCloudNetflix组件中的一个轻量级RESTFUL和HTTP服务客户端,实现了负载均衡和Rest调用的开源框架,封装了Ribbon和RestTemplate,实现了webService的面向接口编程,进一步降低了项目的耦合度。是一种声... 查看详情
springcloud——feign声明式服务调用(代码片段)
什么是FeignFeign是SpringCloudNetflix组件中的一个轻量级RESTFUL和HTTP服务客户端,实现了负载均衡和Rest调用的开源框架,封装了Ribbon和RestTemplate,实现了webService的面向接口编程,进一步降低了项目的耦合度。是一种声... 查看详情
springcloud入门教程:用声明式rest客户端feign调用远端http服务
首先简单解释一下什么是声明式实现?要做一件事,需要知道三个要素,where,what,how。即在哪里(where)用什么办法(how)做什么(what)。什么时候做(when)我们纳入how的范畴。1)编程式实现:每一个要素(where,what,how)都... 查看详情
openfeign:声明式服务调用
SpringCloudOpenFeign:声明式服务调用一、OpenFeign简介1.什么是OpenFeignOpenFeign目前是SpringCloud二级子项目。平时说的Feign指的是Netflix下的Feign,现在我们学习的是OpenFeign,是Spring提供的。OpenFeign是一种声明式、模板化的HTTP客户端(... 查看详情
openfeign:声明式服务调用
SpringCloudOpenFeign:声明式服务调用一、OpenFeign简介1.什么是OpenFeignOpenFeign目前是SpringCloud二级子项目。平时说的Feign指的是Netflix下的Feign,现在我们学习的是OpenFeign,是Spring提供的。OpenFeign是一种声明式、模板化的HTTP客户端(... 查看详情
springcloud体系介绍
SpringCloud体系介绍SpringCloudNetflixNetflixEureka:服务治理组件,包含服务注册与发现NetflixRibbon:客户端负载均衡的服务调用组件NetflixHystrix:容错管理组件,实现了熔断器NetflixFeign:基于Ribbon和Hystrix的声明式、模板化的HTTP服务调用... 查看详情
springcloud——feign声明式服务调用(代码片段)
什么是FeignFeign是SpringCloudNetflix组件中的一个轻量级RESTFUL和HTTP服务客户端,实现了负载均衡和Rest调用的开源框架,封装了Ribbon和RestTemplate,实现了webService的面向接口编程,进一步降低了项目的耦合度。是一种声... 查看详情
springcloud之feign实现声明式rest调用
...的HTTP客户端,可帮助我们更加便捷、优雅的调用HTTPapi。springcloud对Feign进行了增强,使Feign支持了SpringMVC注解,并整合了Ribbon和Eureka,从而让Feign的使用更加方便:只需要创建一个接口,并在接口上添加一些注解,代码就完成了... 查看详情
springcloud无废话入门03:feign声明式服务调用
1.Feign概述 在上一篇的HelloService这个类中,我们有这样一行代码: returnrestTemplate.getForObject("http://hello-service/hello",String.class); 查看详情
springcloud远程调用-openfeign
参考技术AOpenFeign是SpringCloud提供的一个声明式客户端组件,可以通过注解和接口的组合实现服务的远程接口调用,并且与Eureka和Ribbon组合使用能够实现负载均衡的效果1.在pom.xml中引入依赖2.在主启动类上添加@EnableFeignClients注解,... 查看详情
干货分享微服务spring-cloud(5.声明式服务调用feign)
Springcloudfeign基于Netflixfeign实现,整合了springcloudribbon与springcloudhystrix,除了提供这两者的强大功能之外,它还提供了一种声明式的web服务客户端定义方式新建springboot工程并命名为demo-springcloud-feign-consumer,新建启动类FeignApplication... 查看详情
springcloud:feign的应用
1、概念 Feign是一种声明式、模板化的HTTP客户端,是一个声明web服务客户端,这便得编写web服务客户端更容易。2、应用 2.1、在项目中,模块与模块之间需要互相调用,比如web模块需要调用service模块的服务,这个时候... 查看详情
springcloud系列四feign远程调用服务
一:Feign简介Feign是一种声明式、模板化的HTTP客户端,在SpringCloud中使用Feign,可以做到使用HTTP请求远程服务时能与调用本地方法一样的编码体验,开发者完全感知不到这是远程方法,更感知不到这是个HTTP请求。Feign的灵感来源... 查看详情
springcloud简介
参考技术ASpringCloud是基于SpringBoot基础之上开发的微服务框架,SpringCloud是一套目前非常完整的微服务解决方案框架,其内容包含服务治理、注册中心、配置管理、断路器、智能路由、微代理、控制总线、全局锁、分布式会话等。... 查看详情
springcloud(hoxton.sr3)基础篇:第六章feign声明式服务调用
一、Feign简介 在前面的文章中可以发现当我们通过RestTemplate调用其它服务的API时,所需要的参数须在请求的URL中进行拼接,如果参数少的话或许我们还可以忍受,一旦有多个参数的话,这时拼接请求字符串就会效率低下 ... 查看详情
springcloud之openfeign
SpringCloud之openFeignSpringCloud的子项目之一,SpringCloudOpenFeign以将OpenFeign集成到SpringBoot应用中的方式,为微服务架构下服务之间的调用提供了解决方案。首先,利用了OpenFeign的声明式方式定义Web服务客户端;其次还更进一步,通过... 查看详情
springcloud简介
前言:SpringCloud是一款基于SpringBoot实现的微服务框架SpringCloud并不是一个拿来即可用的框架,它是一种微服务规范,共有以下2代实现:第一代实现:SpringCloudNetflix第二代实现:SpringCloudAlibaba1、SpringCloud的常... 查看详情