栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Java

Feign实现服务间的调用及负载均衡

Java 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

Feign实现服务间的调用及负载均衡

1.1 Feign简介 Feign 是简化 Java HTTP 客户端开发的工具(java-to-httpclient-binder),它的灵感 来自于 Retrofit 、 JAXRS-2.0 和 WebSocket 。 Feign 的初衷是降低统一绑定 Denominator 到 HTTP API的复杂度,不区分是否为 restful 。 1.2 快速体验 我们现在在问答微服务调用基础微服务的方法(根据 ID 查询标签) ( 1 )在 zhao588_qa 模块添加依赖   依赖
      
		  org.springframework.cloud
		  spring-cloud-starter-openfeign
	  

(2)在zhao588_qa模块启动类加注解:

@EnableDiscoveryClient
@EnableFeignClients

(3)在zhao588_qa模块创建 com.zhao588.qa.client 包,包下创建接口    
@FeignClient("zhao588-base")
public interface baseClient {

    @RequestMapping(value = "/label/{id}",method = RequestMethod.GET)
     public Result findById(@PathVariable("id") String id);
}
@FeignClient 注解用于指定从哪个服务中调用功能 ,注意 里面的名称与被调用的服务 名保持一致,并且不能包含下划线。 @RequestMapping 注解用于对被调用的微服务进行地址映射。注意 @PathVariable 注 解一定要指定参数名称,否则出错 (5) 修改zhao588_qa模块的 ProblemController
    @Autowired
	private baseClient baseClient;//报红线不用管,idea版本造成的,不影响。

	@RequestMapping(value = "/label/{id}",method = RequestMethod.GET)
	public Result findByLabelId(@PathVariable String id){
		Result result = baseClient.findById(id);
		return result;
	}

(6)测试(先启动zhao588_eureka,zhao588_qa,zhao588_base)

2.1 负载均衡

通过一个服务调用多个服务,测试:同时开启多个基础微服务,看是否是轮流调用。

(1)首先启动zhao588_eureka被调用服务

 (2)修改zhao588_base服务端口多次启动

         a,修改端口:9101 

           

            接口 

            

           启动

        b,修改端口:9201 

          

        接口

   启动

 (3) 启动zhao588_qa调用服务

 (4)测试

第一次刷新:http://localhost:9003/problem/label/1451434101826523136

 结果:发现走的9201端口服务

  第二次刷新:http://localhost:9003/problem/label/1451434101826523136

  结果:发现走的9101端口服务

 第三次刷新:http://localhost:9003/problem/label/1451434101826523136

  结果:发现走的9101端口服务

多次测试就会发现他们每次请求都会轮流调用。 

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/631264.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号