springboot3.3.5 集成elasticsearch8.12.2 ssl 通过 SSL bundle name 来实现

看到你在 Spring Boot 3.3.5 中配置 Elasticsearch 时遇到了 SSL bundle name 'es-ssl-bundle' cannot be found 的错误。这个问题通常是因为你在配置中指定了一个名为 es-ssl-bundle 的 SSL 捆绑包,但 Spring Boot 在它的上下文中并没有找到这个定义好的捆绑包

简单来说,就是你告诉程序要用一个叫"es-ssl-bundle"的安全证书包,但是这个包要么还没创建,要么名字没对应上。

🔧 解决方案:配置 SSL Bundle

Spring Boot 3 引入了 SSL Bundles 的概念,它允许你集中管理 SSL 配置 ,包括信任材料(如证书、私钥)和各种 SSL 选项。你需要通过 application.yml (或 application.properties )明确定义一个名为 es-ssl-bundle 的 SSL 捆绑包,并指定证书的路径和类型。

以下是修改你的 application.yml 配置的示例:

yaml 复制代码
# application.yml

spring:
  elasticsearch:
    username: elastic
    password: -a_-nPO4EvwEqJhUnECH # 记得确保密码正确哦
    uris: https://192.168.8.140:9200
    restclient:
      ssl:
        bundle: es-ssl-bundle # 这里指向下面定义的 SSL Bundle 名称

# 配置 SSL Bundles
ssl:
  bundle:
    jks: # 你可以根据证书类型选择 jks, pem 或 pkcs12
      es-ssl-bundle: # 这是你在上面引用的 bundle 名称
        key:
          alias: "my-key-alias" # 如果你的密钥库有别名,请指定
          password: "your-keystore-password" # 密钥库的密码
        keystore:
          location: "classpath:elasticsearch/keystore.jks" # 你的 .jks 文件路径
          password: "your-keystore-password" # 密钥库的密码
          type: "JKS" # 密钥库类型,通常是 JKS 或 PKCS12
        truststore:
          location: "classpath:elasticsearch/truststore.jks" # 信任库路径(如果需要验证服务器证书)
          password: "your-truststore-password"

如果你的证书是 PEM 格式 (比如 .crt.key 文件),配置会稍有不同:

yaml 复制代码
# 如果是 PEM 格式证书的配置示例
ssl:
  bundle:
    pem:
      es-ssl-bundle:
        key: # 配置客户端私钥(如果不是双向认证,可能不需要)
          alias: "my-key-alias" 
          password: "your-private-key-password" # 私钥的密码(如果有的话)
        keystore: 
          private-key: "classpath:elasticsearch/client.key" # 你的私钥文件路径
          certificate: "classpath:elasticsearch/client.crt" # 你的证书文件路径
        truststore: 
          certificate: "classpath:elasticsearch/ca.crt" # 你从ES服务器获取的CA证书路径

关键配置说明

  • bundle 名称一致性 :确保 spring.elasticsearch.restclient.ssl.bundle 指定的名称(如 es-ssl-bundle)与在 ssl.bundle 下定义的名称完全一致
  • 证书路径locationprivate-key/certificate 需要指向你确切的证书文件位置。请确保这些文件真的在你说的地方,并且文件名和扩展名都正确。
  • 密码 :如果你的密钥库、信任库或私钥设置了密码,必须提供正确的密码
  • 证书类型 :根据你的证书文件的实际类型(JKS, PKCS12, PEM),在 ssl.bundle 下选择对应的配置节点(jks, pkcs12, pem)。

⚠️ 开发环境临时方案(不推荐用于生产)

如果只是为了在开发环境快速测试,你可以考虑暂时禁用 SSL 证书验证但这会降低连接的安全性,不适合生产环境

yaml 复制代码
spring:
  elasticsearch:
    username: elastic
    password: -a_-nPO4EvwEqJhUnECH
    uris: https://192.168.8.140:9200
    # 移除或注释掉 restclient.ssl.bundle 配置
    # restclient:
    #   ssl:
    #     bundle: es-ssl-bundle
    ssl:
      verification-mode: none # 跳过证书验证(不安全!)

重要提醒verification-mode: none 只是权宜之计,一旦 SSL 捆绑包配置正确,就应该恢复使用捆绑包的方式

💎 核心步骤总结

解决此问题的核心在于正确定义并在 Elasticsearch 配置中引用一个 SSL Bundle。为了帮你更清晰地理解这个流程,我为你梳理了以下的排查和解决步骤:
是 否 定义 Bundle 确定证书类型
JKS/PKCS12 或 PEM 在 application.yml 中
配置 ssl.bundle 段 确保证书文件路径正确 启动报错: SSL bundle not found 在 Elasticsearch 配置中
正确引用定义好的 bundle 名称 问题解决? 成功连接 检查证书内容/密码/路径

这样就可以了。

相关推荐
RollingPin44 分钟前
iOS八股文之 网络
网络·网络协议·ios·https·udp·tcp·ios面试
惘嘫、冋渞6 小时前
AWS同一账号下创建自定义VPC并配置不同区域的对等链接
网络·云计算·aws
云知谷8 小时前
【HTML】网络数据是如何渲染成HTML网页页面显示的
开发语言·网络·计算机网络·html
言之。9 小时前
大模型嵌入 vs ES:语义搜索与关键字搜索
大数据·elasticsearch·搜索引擎
站长朋友10 小时前
【邀请函】锐成信息 × Sectigo | CLM - SSL 证书自动化运维解决方案发布会
运维·自动化·ssl·clm·sectigo·47天ssl证书
阑梦清川10 小时前
es的docker部署和docker相关的可可视化面板工具介绍
大数据·elasticsearch·docker
Mr_LiYYD11 小时前
elasticsearch数据迁移
大数据·elasticsearch·搜索引擎
dalianwawatou12 小时前
GitLab 代码基础操作清单
大数据·elasticsearch·gitlab
呉師傅12 小时前
关于联想ThinkCentre M950t-N000 M大师电脑恢复预装系统镜像遇到的一点问题
运维·网络·windows·电脑
代码AI弗森12 小时前
无状态的智慧:从 HTTP 到大模型的系统进化论
网络·网络协议·http