Springboot报错:Fail fast is set and there was an error reading configuration from consul

Springboot报错:Fail fast is set and there was an error reading configuration from consul

今天搭建springboot集成consul配置中心的时候遇到如下报错

2021-02-09 11:50:11.787 [main] ERROR o.s.c.c.c.ConsulPropertySourceLocator:154 - Fail fast is set and there was an error reading configuration from consul.

点进源码断点查看,看到以下报错导致:
在这里插入图片描述
复制出来是这个

com.ecwid.consul.transport.TransportException: org.apache.http.conn.HttpHostConnectException: Connect to localhost:8500 [localhost/127.0.0.1, localhost/0:0:0:0:0:0:0:1] failed: Connection refused: connect

然后断点到里面看到:
在这里插入图片描述
这里显示的consul地址是:localhost:8500
然后我们实际配置的是:

spring:
  application:
    name: game-gateway-server
  cloud:
    consul:
      host: 127.0.0.1
      port: 2000
      scheme:
      discovery:
        service-name: ${spring.application.name}
        prefer-ip-address: true #表示注册时使用ip而不是hostname
        instance-id: ${spring.application.name}:${spring.cloud.client.ip-address}:${server.port} #实例id
        register: true #配置服务注册
        deregister: true #服务停止时取消注册
        health-check-critical-timeout: 30s  #健康检查失败多长时间取消注册
      config:
        enabled: true # 启用配置中心
        prefix: test
        format: KEY_VALUE # 表示consul上面文件的格式 有四种 YAML PROPERTIES KEY-VALUE FILES
        data-key: data #表示consul上面的KEY值(或者说文件的名字) 默认是data

说明consul拉取配置中心的时候,我们的配置并未生效

解决办法:

创建bootstrap.yml,将配置拷贝到bootstrap.yml里面去

spring:
  application:
    name: game-gateway-server
  cloud:
    consul:
      host: 127.0.0.1
      port: 2000
      scheme:
      discovery:
        service-name: ${spring.application.name}
        prefer-ip-address: true #表示注册时使用ip而不是hostname
        instance-id: ${spring.application.name}:${spring.cloud.client.ip-address}:${server.port} #实例id
        register: true #配置服务注册
        deregister: true #服务停止时取消注册
        health-check-critical-timeout: 30s  #健康检查失败多长时间取消注册
      config:
        enabled: true # 启用配置中心
        prefix: test
        format: KEY_VALUE # 表示consul上面文件的格式 有四种 YAML PROPERTIES KEY-VALUE FILES
        data-key: data #表示consul上面的KEY值(或者说文件的名字) 默认是data

再次重启,读取成功

### 解决 Spring Boot 应用部署时遇到的 Kubernetes API Server 拒绝连接问题 当尝试通过 `kubectl` 命令获取 Pod 列表时,如果收到错误消息“The connection to the server localhost:8080 was refused”,这通常意味着客户端无法与 Kubernetes API Server 正常通信[^1]。 #### 可能的原因分析 1. **Kubernetes 配置文件缺失或不正确** 如果 `$HOME/.kube/config` 文件不存在或者配置有误,则默认情况下 `kubectl` 尝试连接本地运行的 Kubernetes API Server(即 `localhost:8080`)。对于大多数生产环境而言,API Server 不会在此地址监听请求[^3]。 2. **环境变量未设置** 若集群访问所需的认证信息和其他必要参数没有被正确加载到环境中,可能会导致类似的连接失败情况。确保已按照文档说明,在 `~/.bashrc` 中适当设置了 KUBECONFIG 或其他相关环境变量。 3. **网络连通性和权限问题** 即使拥有正确的配置文件和环境变量,仍然可能存在防火墙阻止、DNS 解析失败或是用户账户缺乏足够的权限等问题影响正常通讯。 4. **Consul 配置读取失败** 对于依赖 Consul 进行服务发现的应用程序来说,“Fail fast is set and there was an error reading configuration from consul.” 的提示表明应用程序在启动初期就因为未能成功从 Consul 获取所需配置而快速终止了进程[^2]。 #### 推荐解决方案 为了有效解决问题并顺利部署 Spring Boot 应用: - 确认当前使用的 kubeconfig 文件路径是否正确无误; - 使用命令 `export KUBECONFIG=<path-to-your-kubeconfig-file>` 来临时指定有效的配置文件位置; - 编辑 `~/.bashrc` 添加持久化的环境变量定义; - 测试能否 ping 通目标服务器以及 telnet 至相应端口验证网络可达性; - 查看是否有 SELinux/AppArmor 等安全模块干扰; - 审查日志记录寻找更多线索以便进一步排查具体原因。 ```shell # 设置 KUBECONFIG 环境变量指向正确的配置文件 export KUBECONFIG=/etc/kubernetes/admin.conf ```
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值