软件 ipsec 对接 h3c 防火墙 ipsec 对上了一半

对上了一半是指:

  1. 防火墙显示连接已建立,软件 ipsec 显示连接无法建立。这是一半
  2. 软件 ipsec 显示500端口 psk认证成功,但是自适应到 4500端口,认证失败。这是一半

端口和4500端口校验一个成功,一个失败,这两个阶段有什么区别?

bash 复制代码
root@csy-wx-pm-os01-eis-node03:/etc/swanctl#  swanctl --initiate --child net-net  mars-moon
[IKE] initiating IKE_SA mars-moon[16] to 10.22.255.89
[ENC] generating IKE_SA_INIT request 0 [ SA KE No N(NATD_S_IP) N(NATD_D_IP) N(FRAG_SUP) N(HASH_ALG) N(REDIR_SUP) ]
[NET] sending packet: from 10.251.174.200[500] to 10.22.255.89[500] (400 bytes)
[NET] received packet: from 10.22.255.89[500] to 10.251.174.200[500] (368 bytes)
[ENC] parsed IKE_SA_INIT response 0 [ SA KE No N(NATD_S_IP) N(NATD_D_IP) ]
[CFG] selected proposal: IKE:AES_CBC_256/HMAC_SHA2_256_128/PRF_HMAC_SHA2_256/MODP_1536
[IKE] faking NAT situation to enforce UDP encapsulation
[IKE] authentication of '10.251.174.200' (myself) with pre-shared key
[IKE] establishing CHILD_SA net-net{23}
[ENC] generating IKE_AUTH request 1 [ IDi N(INIT_CONTACT) IDr AUTH SA TSi TSr N(MOBIKE_SUP) N(ADD_4_ADDR) N(ADD_4_ADDR) N(ADD_4_ADDR) N(ADD_4_ADDR) N(ADD_4_ADDR) N(ADD_6_ADDR) N(ADD_6_ADDR) N(ADD_6_ADDR) N(EAP_ONLY) N(MSG_ID_SYN_SUP) ]
[NET] sending packet: from 10.251.174.200[4500] to 10.22.255.89[4500] (400 bytes)
[NET] received packet: from 10.22.255.89[4500] to 10.251.174.200[4500] (144 bytes)
[ENC] parsed IKE_AUTH response 1 [ N(NO_PROP) IDr AUTH N(MSG_ID_SYN_SUP) ]
[IKE] authentication of '10.22.255.89' with pre-shared key successful
[IKE] IKE_SA mars-moon[16] established between 10.251.174.200[10.251.174.200]...10.22.255.89[10.22.255.89]
[IKE] scheduling rekeying in 84491s
[IKE] maximum IKE_SA lifetime 86291s
[IKE] received NO_PROPOSAL_CHOSEN notify, no CHILD_SA built
[IKE] failed to establish CHILD_SA, keeping IKE_SA ipsec 

500 端口和4500端口校验一个成功,一个失败,这两个阶段有什么区别?

在 IKE (Internet Key Exchange) 的过程中,使用 500 端口和 4500 端口来处理不同的阶段和内容。下面我们将分别分析这两个阶段的作用和它们之间的区别。

1. IKE 过程概览

  • 500 端口:用于 IKEv1 和 IKEv2 中的初始密钥交换阶段。主要用于加密安全关联 (SA) 的建立。
  • 4500 端口:用于 NAT(网络地址转换) 环境中的UDP封装,以便在 NAT 设备后面进行通信。其作用主要是在 IKEv2 的后续阶段和 CHILD_SA 的建立中。

2. 500 端口的作用

  • 步骤 :在使用 500 端口时,主要处理初步的 IKE SA 初始化请求和响应。这包括:
    • 交换 SA(安全关联)信息。
    • 进行密钥交换。
    • 交换 Nonce(随机数)。
  • 发送和接收数据包 :在你的日志中,sending packet: from 10.251.174.200[500] to 10.22.255.89[500] 和相应的接收响应是在此阶段完成的。
  • 认证:认证通常会在此阶段进行,包括使用预共享密钥(PSK)来验证身份。

3. 4500 端口的作用

  • 步骤:在使用 4500 端口时,主要处理 NAT 情况下的 IKE 消息。这是因为某些 NAT 设备可能会丢失 UDP 500 端口的报文,因此 IKEv2 使用 UDP 4500 来确保可达性。
  • 发送和接收数据包 :例如,sending packet: from 10.251.174.200[4500] to 10.22.255.89[4500] 和接收到对应响应时使用的是 4500 端口。
  • 子安全关联的创建 :在这一步,你尝试建立 CHILD_SA,但根据日志显示 N(NO_PROP),表明双方没有达成一致,无法建立子 SA。

4. 成功与失败的原因

  • 认证成功authentication of '10.22.255.89' with pre-shared key successful 表明初始的身份验证成功,并且 IKE SA 在 500 端口的建立是成功的。
  • CHILD_SA 失败 :在使用 4500 端口时,尽管 IKE SA 成功,但在尝试建立 CHILD_SA 时,出现了 NO_PROPOSAL_CHOSEN 的提示。这说明客户端和服务器没有找到匹配的提案,因此子安全关联没有建立。

结论与检查

  1. 检查提案配置

    • 确保双方的 IKE 和 CHILD_SA ESP 提案(包括加密算法、完整性算法和 DH 组)配置一致。
  2. 流量选择器

    • 检查 Traffic Selectors(TSi 和 TSr)是否匹配,这将在 CHILD_SA 的构建中起到关键作用。
  3. 协议支持

    • 确认双方对 NAT 的支持情况,特别是在涉及多个 NAT 设备的网络环境中。

通过确保 IKE 和 CHILD_SA 提案的一致性、流量选择器的正确性,你将能够解决 CHILD_SA 创建失败的问题。

相关推荐
苏三说技术12 分钟前
Prompt、Agent、Function Call、Skill、MCP,傻傻分不清楚?
后端
小码哥_常22 分钟前
Spring Boot接口幂等保护:一个注解开启数据一致性守护
后端
我叫黑大帅23 分钟前
Go中的interface的两大用法
后端·面试·go
神秘的猪头27 分钟前
🚀 React 开发者进阶:RAG 核心——手把手带你玩转 Milvus 向量数据库
数据库·后端·llm
navms27 分钟前
NameServer 极简设计的哲学
后端
小码哥_常27 分钟前
Spring Boot 4.0 牵手RabbitMQ死信队列,解锁消息处理新姿势
后端
於時光清歌37 分钟前
Git基础使用
后端
明月_清风1 小时前
Python 性能微观世界:列表推导式 vs for 循环
后端·python
风象南1 小时前
纯文本模型竟然也能直接“画图”,而且还很好用
前端·人工智能·后端
明月_清风1 小时前
Python 性能翻身仗:从 O(n) 到 O(1) 的工程实践
后端·python