Apache APISIX 中配置 ApisixTls 实现 SSL 上游服务的实践指南
2025-05-15 21:53:10作者:霍妲思
问题背景
在使用 Apache APISIX 作为 API 网关时,我们经常需要处理上游服务启用 SSL/TLS 的情况。当尝试通过 ApisixTls 资源配置 SSL 连接时,可能会遇到 "tlsv1 alert internal error" 的错误提示。这种错误通常表明 SSL 握手过程中出现了问题,可能是由于证书配置不当或双向认证(mTLS)验证失败导致的。
错误现象分析
典型的错误表现为客户端在尝试建立 TLS 连接时,服务器返回了内部错误:
TLSv1.3 (OUT), TLS handshake, Client hello (1):
TLSv1.3 (IN), TLS alert, internal error (592):
error:14094438:SSL routines:ssl3_read_bytes:tlsv1 alert internal error
这种错误可能出现在以下场景中:
- 客户端证书验证失败
- 服务器证书链不完整
- 双向认证配置不正确
- SNI(服务器名称指示)不匹配
ApisixTls 配置解析
Apache APISIX 提供了 ApisixTls 自定义资源来管理 TLS 配置。一个典型的配置示例如下:
apiVersion: apisix.apache.org/v2
kind: ApisixTls
metadata:
name: my-tls
spec:
hosts:
- example.com
secret:
name: app-secret
namespace: default
client:
caSecret:
name: app-ca-secret
namespace: default
depth: 10
这个配置定义了:
- 主机名(SNI)为 example.com
- 使用 default 命名空间中的 app-secret 作为服务器证书
- 启用客户端证书验证,使用 app-ca-secret 作为 CA 证书
- 设置证书链验证深度为 10
解决方案:实现部分路径的 mTLS 豁免
在某些场景下,我们可能希望对特定路径豁免双向认证(mTLS)要求。Apache APISIX 支持通过正则表达式匹配 URI 来实现这一功能。
虽然 ApisixTls CRD 目前不支持直接配置 skip_mtls_uri_regex 字段,但可以通过以下两种方式实现:
方法一:使用 Admin API 直接配置
通过 APISIX 的 Admin API 可以直接创建包含 skip_mtls_uri_regex 的 SSL 配置:
curl http://127.0.0.1:9180/apisix/admin/ssls/1 \
-H 'X-API-KEY: edd1c9f034335f136f87ad84b625c8f1' -X PUT -d '
{
"sni": "example.com",
"cert": "<证书内容>",
"key": "<私钥内容>",
"client": {
"ca": "<CA证书内容>",
"depth": 10,
"skip_mtls_uri_regex": ["^/api/health$", "^/public/.*"]
}
}'
方法二:修改 APISIX 配置
在 config.yaml 中添加全局配置:
apisix:
ssl:
ssl_trusted_certificate: /path/to/ca.crt
skip_mtls_uri_regex: ["^/api/health$", "^/public/.*"]
最佳实践建议
- 证书管理:确保证书链完整,包括中间证书
- SNI 匹配:检查客户端请求中的 SNI 是否与配置匹配
- 测试验证:使用 openssl s_client 命令进行详细诊断
- 渐进式部署:先测试非生产环境,再应用到生产
- 监控告警:配置适当的监控以捕获 TLS 握手失败
总结
处理 Apache APISIX 中的 TLS 配置需要仔细检查证书链、SNI 匹配和双向认证设置。对于需要部分豁免 mTLS 的场景,虽然 ApisixTls CRD 目前不支持直接配置,但可以通过 Admin API 或修改配置文件实现。随着 APISIX 的版本更新,未来可能会在 CRD 中增加更多灵活的 TLS 配置选项。
登录后查看全文
热门项目推荐
相关项目推荐
atomcodeClaude Code 的开源替代方案。连接任意大模型,编辑代码,运行命令,自动验证 — 全自动执行。用 Rust 构建,极致性能。 | An open-source alternative to Claude Code. Connect any LLM, edit code, run commands, and verify changes — autonomously. Built in Rust for speed. Get StartedRust0152- DDeepSeek-V4-ProDeepSeek-V4-Pro(总参数 1.6 万亿,激活 49B)面向复杂推理和高级编程任务,在代码竞赛、数学推理、Agent 工作流等场景表现优异,性能接近国际前沿闭源模型。Python00
LongCat-Video-Avatar-1.5最新开源LongCat-Video-Avatar 1.5 版本,这是一款经过升级的开源框架,专注于音频驱动人物视频生成的极致实证优化与生产级就绪能力。该版本在 LongCat-Video 基础模型之上构建,可生成高度稳定的商用级虚拟人视频,支持音频-文本转视频(AT2V)、音频-文本-图像转视频(ATI2V)以及视频续播等原生任务,并能无缝兼容单流与多流音频输入。00
auto-devAutoDev 是一个 AI 驱动的辅助编程插件。AutoDev 支持一键生成测试、代码、提交信息等,还能够与您的需求管理系统(例如Jira、Trello、Github Issue 等)直接对接。 在IDE 中,您只需简单点击,AutoDev 会根据您的需求自动为您生成代码。Kotlin03
Intern-S2-PreviewIntern-S2-Preview,这是一款高效的350亿参数科学多模态基础模型。除了常规的参数与数据规模扩展外,Intern-S2-Preview探索了任务扩展:通过提升科学任务的难度、多样性与覆盖范围,进一步释放模型能力。Python00
skillhubopenJiuwen 生态的 Skill 托管与分发开源方案,支持自建与可选 ClawHub 兼容。Python0112
热门内容推荐
最新内容推荐
项目优选
收起
暂无描述
Dockerfile
733
4.75 K
Ascend Extension for PyTorch
Python
618
795
openEuler内核是openEuler操作系统的核心,既是系统性能与稳定性的基石,也是连接处理器、设备与服务的桥梁。
C
433
395
本项目是CANN提供的数学类基础计算算子库,实现网络在NPU上加速计算。
C++
1.01 K
1.01 K
Claude Code 的开源替代方案。连接任意大模型,编辑代码,运行命令,自动验证 — 全自动执行。用 Rust 构建,极致性能。 | An open-source alternative to Claude Code. Connect any LLM, edit code, run commands, and verify changes — autonomously. Built in Rust for speed.
Get Started
Rust
1.18 K
152
deepin linux kernel
C
29
16
华为昇腾面向大规模分布式训练的多模态大模型套件,支撑多模态生成、多模态理解。
Python
145
237
暂无简介
Dart
983
252
昇腾LLM分布式训练框架
Python
166
198
🎉 (RuoYi)官方仓库 基于SpringBoot,Spring Security,JWT,Vue3 & Vite、Element Plus 的前后端分离权限管理系统
Vue
1.68 K
989