软件 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 创建失败的问题。

相关推荐
文艺理科生1 分钟前
Nginx 路径映射深度解析:从本地开发到生产交付的底层哲学
前端·后端·架构
千寻girling2 分钟前
主管:”人家 Node 框架都用 Nest.js 了 , 你怎么还在用 Express ?“
前端·后端·面试
南极企鹅4 分钟前
springBoot项目有几个端口
java·spring boot·后端
Luke君607976 分钟前
Spring Flux方法总结
后端
define95279 分钟前
高版本 MySQL 驱动的 DNS 陷阱
后端
忧郁的Mr.Li43 分钟前
SpringBoot中实现多数据源配置
java·spring boot·后端
暮色妖娆丶1 小时前
SpringBoot 启动流程源码分析 ~ 它其实不复杂
spring boot·后端·spring
Coder_Boy_2 小时前
Deeplearning4j+ Spring Boot 电商用户复购预测案例中相关概念
java·人工智能·spring boot·后端·spring
Java后端的Ai之路2 小时前
【Spring全家桶】-一文弄懂Spring Cloud Gateway
java·后端·spring cloud·gateway
野犬寒鸦2 小时前
从零起步学习并发编程 || 第七章:ThreadLocal深层解析及常见问题解决方案
java·服务器·开发语言·jvm·后端·学习