文档章节

(二)基于Spring Cloud Feign的客户端互相调用

Twelve_ZX
 Twelve_ZX
发布于 2017/04/07 16:09
字数 729
阅读 82
收藏 2

在我们将服务注册到Eureka服务器上之后,一个应用要调用另一个应用的服务。这个问题怎么解决。

我的场景如下

Eureka服务器 在本地 使用端口 8761

用例1:本地,使用端口8080 有一个greeting服务

用例2:本地,使用端口9000 有一个greeting服务

如何在用例1里面请求到用例2里面的greeting方法

首先想到的解决方案如下:

1:JDK原生 URLConnection。用这个我们通过Eureka获取Eureka提供了discoveryClient类,这个类通过getInstances(用例名)获取用例的详细信息和所需调用服务的域名,端口信息。获取这个信息之后拼接Url字符串。然后使用URLConnection去模拟请求.

2:Eureka给我们提供了一个解决方案 看如下代码:

RestTemplate restTemplate = new RestTemplate();
ResponseEntity<String> resultStr=
        restTemplate.getForEntity("http://localhost:9000/greeting", String.class);
		System.out.println(resultStr.getBody());
		return resultStr.getBody();

我们可以使用RestTemplate去访问端口为9000的greeting方法,同样采用的是拼接URL的方法。结果如下:

3:那就是Spring Cloud Feign了。这个工具提供了非常完成的一套解决方案,我们只需要告诉他服务名/用例名 他就回去获取服务用例的对应的请求地址和端口,接下来我们具体的说一下这个调用

首先在用例1里面配置pom添加Feign的依赖包

<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/maven-v4_0_0.xsd">
  <modelVersion>4.0.0</modelVersion>
  <groupId>com.zx</groupId>
  <artifactId>SpringCloudClient</artifactId>
  <version>0.0.1-SNAPSHOT</version>
  <parent>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-parent</artifactId>
    <version>1.3.5.RELEASE</version>
    <relativePath/>
  </parent>

  <properties>
    <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
    <java.version>1.7</java.version>
  </properties>

  <dependencyManagement>
    <dependencies>
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-parent</artifactId>
            <version>Brixton.SR3</version>
            <type>pom</type>
            <scope>import</scope>
        </dependency>
    </dependencies>
  </dependencyManagement>

  <dependencies>
      <!--此处是差异所在-->
      <dependency>
          <groupId>org.springframework.cloud</groupId>
          <artifactId>spring-cloud-starter-eureka</artifactId>
      </dependency>
      <dependency>
          <groupId>org.springframework.boot</groupId>
          <artifactId>spring-boot-starter-test</artifactId>
          <scope>test</scope>
      </dependency>
       <!-- 客户端负载均衡jar包 -->
      <dependency>
        <groupId>org.springframework.cloud</groupId>
        <artifactId>spring-cloud-starter-ribbon</artifactId>
      </dependency>
      <!-- 跨服务请求 包 -->
      <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-feign</artifactId>
        </dependency>
  </dependencies>

  <build>
    <plugins>
        <plugin>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-maven-plugin</artifactId>
        </plugin>
    </plugins>
  </build>

</project>

这个包加载之后,我们只需要创建一个接口类(interface)

在这个接口上面启用Feign。然后创建抽象方法,申明要调用的用例2里面的方法即可。代码如下:

package Controller;

import org.springframework.cloud.netflix.feign.FeignClient;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;

@FeignClient("TWO-CLOUD-CLIENT")//配置要请求的用例名,此名称和Eureka的名称一致
public interface getServerController {
    //申明调用方法,以及请求方式
	@RequestMapping(value = "/greeting",method = RequestMethod.GET)
    public  String getGreeting9000(@RequestParam("name") String name);//请求附带一个叫name的参数
}

这样写好之后,这个接口就会注册到Spring的Ioc中。后面我们可以直接使用这个接口调这个方法获取数据了

这个效果和上面使用Eureka的restTemple的效果一致。这样就完成了应用与应用之间的调用

© 著作权归作者所有

共有 人打赏支持
Twelve_ZX
粉丝 10
博文 25
码字总数 25925
作品 0
海淀
程序员
springcloud 客户端负载均衡 ribbon

------------------------------------------------------------------------------------------------------------ springcloud (零) springboot 基础 下载 springcloud (一)服务注册中心 ......

curiousby
2017/02/09
0
0
springcloud 服务网关 gateway zuul

------------------------------------------------------------------------------------------------------------ springcloud (零) springboot 基础 下载 springcloud (一)服务注册中心 ......

curiousby
2017/02/17
0
0
springcloud eureka 服务注册中心

------------------------------------------------------------------------------------------------------------ springcloud (零) springboot 基础 下载 springcloud (一)服务注册中心 ......

curiousby
2017/02/08
0
0
springcloud 断路由hystrix

------------------------------------------------------------------------------------------------------------ springcloud (零) springboot 基础 下载 springcloud (一)服务注册中心 ......

curiousby
2017/02/10
0
0
springcloud 消费者 Feign (类似 webservice)

------------------------------------------------------------------------------------------------------------ springcloud (零) springboot 基础 下载 springcloud (一)服务注册中心 ......

curiousby
2017/02/09
0
0

没有更多内容

加载失败,请刷新页面

加载更多

【大福利】极客时间专栏返现二维码大汇总

我已经购买了如下专栏,大家通过我的二维码你可以获得一定额度的返现! 然后,再给大家来个福利,只要你通过我的二维码购买,并且关注了【飞鱼说编程】公众号,可以加我微信或者私聊我,我再...

飞鱼说编程
今天
1
0
Spring5对比Spring3.2源码之容器的基本实现

最近看了《Spring源码深度解析》,该书是基于Spring3.2版本的,其中关于第二章容器的基本实现部分,目前spring5的实现方式已有较大改变。 Spring3.2的实现: public void testSimpleLoad(){...

Ilike_Java
今天
1
0
【王阳明心学语录】-001

1.“破山中贼易,破心中贼难。” 2.“夫万事万物之理不外于吾心。” 3.“心即理也。”“心外无理,心外无物,心外无事。” 4.“人心之得其正者即道心;道心之失其正者即人心。” 5.“无...

卯金刀GG
今天
2
0
OSChina 周三乱弹 —— 我们无法成为野兽

Osc乱弹歌单(2018)请戳(这里) 【今日歌曲】 @ _刚刚好: 霸王洗发水这波很骚 手机党少年们想听歌,请使劲儿戳(这里) hahahahahahh @嘻酱:居然忘了喝水。 让你喝可乐的话, 你准忘不了...

小小编辑
今天
10
0
vm GC 日志 配置及查看

-XX:+PrintGCDetails 打印 gc 日志 -XX:+PrintTenuringDistribution 监控晋升分布 -XX:+PrintGCTimeStamps 包含时间戳 -XX:+printGCDateStamps 包含时间 -Xloggc:<filename> 可以将数据保存为......

Canaan_
昨天
0
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部