Docker 容器化部署 EtherNet/IP 协议栈(ESDK):Windows 与国产银河麒麟 V10 实测对比

一、 背景:为什么要将 ESDK 容器化?

在工业 4.0 场景下,传统的 EtherNet/IP (EIP) 协议栈部署往往受限于操作系统环境。ESDK (EtherNet/IP Scanner Development Kit) 作为实现 CIP 协议的核心组件,通过 Docker 进行容器化封装,可以实现"一次开发,全现场部署"。

本文将记录 ESDK 在 Windows 10/11 (WSL2)国产化操作系统银河麒麟 V10 环境下的网络模式与通信端口实测结果。


二、 环境准备

测试涉及两个典型的开发与运行环境:

|----------|-------------------------------|-------------------------|
| 维度 | 环境 A:Windows 宿主 | 环境 B:国产化宿主 |
| 操作系统 | Windows 10/11 Professional | 银河麒麟 V10 (Kylin OS) |
| 容器引擎 | Docker Desktop (Hyper-V/WSL2) | 原生 Docker Engine 18.x |
| 协议栈 | ESDK (Linux 版镜像) | ESDK (Linux 版镜像) |


三、 核心技术点:Docker 网络模式

对于 EIP 协议,TCP 44818 (显式报文) 和 UDP 2222 (隐式 I/O) 是核心端口。在 Docker 部署时需注意:

  • Bridge 模式:需手动映射 -p 44818:44818 和 -p 2222:2222/udp。

  • Host 模式:建议在国产 Linux 环境下使用 --net=host,以获得最佳的实时性并支持组播报文。


四、 实测结果对比
  • 稳定性:ESDK 进程在 Docker Desktop 环境下运行极度稳定,无异常退出。

  • 网络连通性:得益于 WSL2 的网络转发,容器内部的 Scanner 与外部真实的 PLC 或模拟器通信完全正常。

  • 兼容性:ESDK 完美适配银河麒麟内核,无需额外补丁。

  • 启动速度:冷启动时间保持在 3-5 秒,适合工业现场快速恢复业务。


五、 终端日志逻辑复盘(重点)

通过日志我们可以清晰地观察到 CIP 协议在容器内的交互流程:

1. 适配器(Adapter)端启动与对象注册:

在容器内运行 ./ConsoleApp3,可以看到协议栈成功注册了 Class 7F 自定义应用对象。

codeBash

复制代码
Custom Application Object registered:
   Class 7F, Instance 1, Attributes 1(Get), 2(Get), 3(Get), 4(Get/Set 2 bytes)
Waiting for a request...

2. 扫描器(Scanner)端非连接请求测试:

运行 ./ConsoleApp2 发起请求。

  • 初次报错:ID 256/257 返回错误,提示路径引用了未知对象。这证明了 ESDK 的异常反馈机制在容器内响应正常。

  • 请求成功:ID 258 成功获得响应数据 5A A5,标志着 UCMM 通道(非连接消息管理器)完全跑通。

    SendUnconnectedRequest ID = 258
    Response for request 258:
    5A A5

3. I/O 连接建立(Class 1 Connection):

通过 ./ConsoleApp1 模拟周期性 I/O 通信。

复制代码
Assembly instances and members created for use over Class 1 connection. 
Connection with instance 1 successfully opened
Connection with instance 1 closed

日志解读:successfully opened 意味着 UDP 2222 端口在 Docker 网桥上通过了流量校验。如果该日志卡在 opening 状态,通常需要检查宿主机防火墙是否放行了 UDP 流量。


六、 结论与建议
  1. 环境对等性:ESDK 在国产银河麒麟与 Windows Docker 环境下的表现高度一致,证明了其优异的跨平台特性。

  2. 网络建议 :在生产环境中,若涉及大规模 I/O 数据交换,建议优先选择银河麒麟环境并开启 Docker 的 Host 网络模式,以消除网桥转发带来的抖动。

相关推荐
王二端茶倒水9 小时前
从千兆到万兆:宽带运营不能只卖套餐,要管用户生命周期从千兆到万兆:宽带运营需要管理用户生命周期
后端·网络协议·架构
程序员老赵11 小时前
Docker 部署 Redmine:老牌开源项目管理部署实测记录
docker·开源·团队管理
程序员老赵12 小时前
服务器文件不想 SFTP 上传?Docker 跑个 File Browser,浏览器就能管理
服务器·docker·开源
extrao3 天前
🚀 Kea DHCP4 自动分配系统完整搭建
网络协议
lichenyang4533 天前
Docker 学习笔记(五):Docker Compose,用一个 YAML 启动前端、后端和 MongoDB
docker
lichenyang4533 天前
Docker 学习笔记(四):Dockerfile,把项目打成自己的镜像
docker·容器
lichenyang4533 天前
Docker 学习笔记(三):Docker 网络、bridge、子网和容器互通
docker·容器
lichenyang4533 天前
Docker 学习笔记(二):docker run 的参数到底在控制什么?
docker·容器
不做菜鸟的网工4 天前
BGP特性
网络协议