SpringCloud -netflix- 负载均衡 Feign 面向注解 接口编程

Feign,主要是社区版,大家都习惯面向接口编程。这个是很多开发人员的规范。调用微服务访问两种方法

微服务名字 【ribbon】
接口和注解 【feign】

Feign能干什么?

  • Feign旨在使编写Java Http客户端变得更容易

  • 前面在使用Ribbon +
    RestTemplate时,利用RestTemplate对Http请求的封装处理,形成了一套模板化的调用方法。但是在实际开发中,由于对服务依赖的调用可能不止一处,往往一个接口会被多处调用,所以通常都会针对每个微服务自行封装一个客户端类来包装这些依赖服务的调用。所以,Feign在此基础上做了进一步的封装,由他来帮助我们定义和实现依赖服务接口的定义,在Feign的实现下,我们只需要创建一个接口并使用注解的方式来配置它
    (类似以前Dao接口上标注Mapper注解,现在是一个微服务接口上面标注一个Feign注解),即可完成对服务提供方的接口绑定,简化了使用Spring
    Cloud Ribbon 时,自动封装服务调用客户端的开发量。
    - Feign默认集成了Ribbon

  • 利用Ribbon维护了MicroServiceCloud-Dept的服务列表信息,并且通过轮询实现了客户端的负载均衡,而与Ribbon不同的是,通过Feign只需要定义服务绑定接口且以声明式的方法,优雅而简单的实现了服务调用。

    使用步骤:

  • 导入依赖

  <dependency>
        <groupId>org.springframework.cloud</groupId>
        <artifactId>spring-cloud-starter-feign</artifactId>
        <version>1.4.6.RELEASE</version>
    </dependency>
配置yml
server:
  port: 8005
  #eureka配置
eureka:
  client:
    fetch-registry: false  #不向eureka中注册自己
    service-url:
      defaultZone: http://localhost:7001/eureka/, http://localhost:7002/eureka/

编写接口(service)(面向接口编程)

同时需要添加注解                @FeignClient(value = "SPRINGCLOUD-02PROVIDER-DEPT")
package com.xuyuan.springcloud.service;

import com.xuyuan.springcloud.pojo.Dept;
import org.springframework.cloud.openfeign.FeignClient;
import org.springframework.stereotype.Component;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.PathVariable;
import org.springframework.web.bind.annotation.PostMapping;

import java.util.List;
				@Service
                @FeignClient(value = "SPRINGCLOUD-02PROVIDER-DEPT")
                @Component
                public interface DeptClientService {
                @GetMapping("/dept/get/{id}")
                    public Dept queryById(@PathVariable("id") Long id);
                @GetMapping("dept/list")
                    public List<Dept> queryAll();
                @PostMapping("dept/add")
                    public boolean addDept(Dept dept);
                }

Controller本质不变

package com.xuyuan.springcloud.controller;
import com.xuyuan.springcloud.pojo.Dept;
import com.xuyuan.springcloud.service.DeptClientService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.*;
import java.util.List;

@RestController
public class DeptConsumerController {
    //理解:消费者,不应该有Service层
    //RestTemptate 。。。。。供我们直接调用就好   注册到BEAN中
//url,实体 map Class<T> resoponseType

        @Autowired
    DeptClientService service=null;
 //本质上还是和ribbon一样的,只是java是面向接口编程的语言,所以feign就出来了
        @GetMapping("/consumer/dept/add")
        public boolean add(Dept dept){
            return this.service.addDept(dept);
        }
        @GetMapping("/consumer/dept/get/{id}")
    public Dept Get(@PathVariable("id") Long id){
            return service.queryById(id);
                }
        @PostMapping("/consumer/dept/list")
    public List<Dept> list(){
            return this.service.queryAll();
        }
}

Feign是面向接口编程,更加符合java程序员的编程习惯,当然各有各的好处,可以根据个人习惯而定,如果喜欢REST风格使用Ribbon;如果喜欢社区版的面向接口风格使用Feign.

springcloud-netflix是一个基于Spring Cloud的微服务框架。它提供了一系列工具和组件来简化开发和管理分布式系统的任务。其中包括Eureka、Feign和Zuul等组件。 在搭建springcloud-netflix项目时,需要创建父工程和子工程。父工程是springcloud-netflix-parent,子工程可以是springcloud-netflix-eureka、springcloud-netflix-service-pay等。每个子工程都需要在pom.xml文件中导入相应的依赖。 对于springcloud-netflix-eureka,需要导入spring-cloud-starter-netflix-eureka-server和spring-cloud-starter-netflix-eureka-client等依赖。此外,还需要配置相关的类。 对于springcloud-netflix-service-pay,需要导入spring-cloud-starter-netflix-eureka-client、spring-boot-starter-web和spring-cloud-starter-openfeign等依赖。同样,也需要配置相关的类。 对于Zuul,它是一个API Gateway服务器,提供了动态路由、监控、弹性和安全等边缘服务的框架。在搭建Zuul时,需要导入spring-cloud-starter-netflix-eureka-client、spring-boot-starter-web和spring-cloud-starter-netflix-zuul等依赖。同时,需要配置开启Zuul。 总之,springcloud-netflix是一个基于Spring Cloud的微服务框架,包括了Eureka、Feign和Zuul等组件,可以帮助简化开发和管理分布式系统的任务。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* *3* [SpringCloudNetflix](https://blog.csdn.net/Exist_W/article/details/131867868)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 100%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值