springboot使用openfeign固定ip请求进行负载均衡

springboot使用openfeign固定ip请求

一个单体springboot项目,请求外部接口,这里想用一下openfeign,没有注册中心,又不能直接请求外部域名(会走流量滴),想着openfeign也是可以指定url进行请求的,但是外部接口又多项目部署,还让请求的时候负载均衡一下,怎么搞,openfeign请求url的时候轮询一下?看看网上一堆重写这,重写那的,好复杂,这里记录一下最后我这边怎么做的吧。

项目版本

 <parent>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-parent</artifactId>
        <version>2.5.4</version>
        <relativePath/> <!-- lookup parent from repository -->
    </parent>
     
      <properties>
        <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
        <java.version>1.8</java.version>
        <spring-cloud.version>2020.0.4</spring-cloud.version>
        <spring-boot.version>2.5.4</spring-boot.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-loadbalancer</artifactId>
        </dependency>


    </dependencies>
    <dependencyManagement>
        <dependencies>
            <dependency>
                <groupId>org.springframework.cloud</groupId>
                <artifactId>spring-cloud-dependencies</artifactId>
                <version>${spring-cloud.version}</version>
                <type>pom</type>
                <scope>import</scope>
            </dependency>

            <!-- SpringBoot 依赖配置 -->
            <dependency>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-dependencies</artifactId>
                <version>${spring-boot.version}</version>
                <type>pom</type>
                <scope>import</scope>
            </dependency>

        </dependencies>

    </dependencyManagement>

注意:这里的版本很重要!!!这里的版本很重要!!!这里的版本很重要!!!

配置文件

就配置了一个:

feign:
  httpclient:
    enabled: true

config

核心其实就是自定义config

import org.apache.commons.lang3.StringUtils;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.cloud.client.DefaultServiceInstance;
import org.springframework.cloud.loadbalancer.core.ServiceInstanceListSupplier;
import org.springframework.cloud.loadbalancer.support.ServiceInstanceListSuppliers;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;


@Configuration
public class LoadBalancerConfig {

    @Bean
    public ServiceInstanceListSupplier serviceInstanceListSupplier() {

 //这里要看自己引用的openfeign和loadbalancer版本
            return ServiceInstanceListSuppliers.from("my-service",
                    new DefaultServiceInstance("my-service", "my-service", "127.0.0.1", 9990, false),
                    new DefaultServiceInstance("my-service", "my-service", "127.0.0.1", 9991, false)
            );
        
    }
}

要注意版本:不同版本的DefaultServiceInstance构造器是不一样的!

feign接口

@FeignClient(name="my-service",url="",configuration = LoadBalancerConfig.class)
public interface TestService {

    //具体请求接口地址
    @GetMapping("/test")
    String getTest(@RequestParam("id") List<Long> ids);

}

开启配置

@EnableFeignClients(basePackages = {"你的feign接口所在包"})
public class TestApp {
public static void main( String[] args )
    {
        SpringApplication.run(TestApp.class, args);
        System.out.println("---TestApp启动完成----");
    }
}

实际调用

@Service
public class TestServiceImpl implements TestService {


    @Autowired
    private TestService testService;
    
    @Override
    public void test() {
        String response = zhishuService.getItemPutAwayTimeCenter(itemIds);
        System.out.println("哇卡卡,我真是个小天才!!");
    }

}

外部接口

不贴了,反正就是轮询调用了,嘎嘎!!!

### OpenFeign使用教程与常见问题解析 #### 一、OpenFeign 的基本概念 OpenFeignSpring Cloud 提供的一个声明式的 HTTP 客户端工具,它基于 Netflix Feign 实现,并扩展了对 Spring MVC 注解的支持。开发者可以通过定义简单的接口并标注相应的注解来完成服务间的远程调用[^3]。 #### 二、引入依赖 为了在项目中使用 OpenFeign,需要添加如下 Maven 依赖: ```xml <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-openfeign</artifactId> </artifactId> ``` 此依赖会自动集成 Ribbon 负载均衡功能以及 Hystrix 断路器(如果配置了相关组件),从而简化微服务架构中的服务调用过程[^1]。 #### 三、启用 OpenFeign 功能 要在应用程序中启用 OpenFeign 支持,需在启动类上添加 `@EnableFeignClients` 注解。例如: ```java @SpringBootApplication @EnableFeignClients public class Application { public static void main(String[] args) { SpringApplication.run(Application.class, args); } } ``` #### 四、创建 Feign Client 接口 通过定义一个带有 `@FeignClient` 注解的接口,可以轻松实现对外部服务的调用。下面是一个典型的例子: ```java @FeignClient(name = "service-name", url = "http://example.com") // 如果注册中心存在,则无需指定url属性 public interface ExampleService { @GetMapping("/api/resource/{id}") ResponseEntity<String> getResource(@PathVariable("id") String id); @PostMapping("/api/resource") ResponseEntity<Void> createResource(@RequestBody Resource resource); } ``` 上述代码片段展示了如何利用 `@FeignClient` 标准的 Spring MVC 注解构建客户端接口。 #### 五、自定义配置 有时可能需要调整 OpenFeign 行为,比如设置超时时间或者增加全局请求头信息。这可通过编写 Bean 配置文件达成。以下是两个常见的场景说明: ##### (1)修改读取/连接超时参数 当未显式设定这些值时,默认采用的是 Ribbon 中的相关配置项。 ```yaml ribbon: ReadTimeout: 5000 ConnectTimeout: 3000 ``` ##### (2)添加 Request Interceptor 借助拦截器机制可统一处理跨域认证等问题。 ```java @Component public class CustomRequestInterceptor implements RequestInterceptor { @Override public void apply(RequestTemplate template) { template.header("Authorization", "Bearer token"); } } ``` #### 六、常见问题解答 1. **Q:** 如何确认当前环境是否启用了负载均衡? **A:** 若已成功导入 spring-cloud-starter-openfeign 并正确配置 Eureka Server 地址,在实际运行期间访问目标资源路径前缀应替换为对应的服务名而非具体 IP 地址即可触发 ribbon 自动分配实例操作[^4]。 2. **Q:** 发生 NoClassDefFoundError 错误怎么办? **A:** 这通常表明缺少某些必要的库文件,请仔细核验 pom.xml 文件内容确保所有必需模块均已加入工程之中[^2]。 3. **Q:** 日志级别较低无法查看内部执行细节该如何改善? **A:** 修改 application.yml 设置 logger.level.org.springframework.cloud.openfeign=DEBUG 即能获取更详尽的日志记录以便排查异常状况。 ---
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值