错误处理
EtherCAT 通信中的错误处理策略和常见故障排查。
错误类型
| 类型 | 来源 | 处理方式 |
|---|---|---|
| AL Status Code | 从站状态转换失败 | 通过 slave.ErrorCode() 读取,使用 EtherCATTypes.classifyALError() 分类 |
| SDO Error | CoE 读写失败 | SDO 方法返回 null 或 false |
| PDO 丢帧 | 通信异常 | 通过 PDOFrameLoss 事件 监控 |
| Emergency | 从站硬件/固件错误 | 通过 Emergency 事件 接收 |
| 状态降级 | 从站异常回退 | 通过 StateChanged 事件 监控 |
| RuntimeException | 工厂方法失败 | EtherCATMaster.create() 初始化失败时抛出 |
状态转换错误
检测方式
boolean ok = master.setState(EcState.OP);
if (!ok) {
System.out.println("状态转换失败");
for (Slave slave : master.Slaves()) {
EtherCATTypes.EcALState errorCode = slave.ErrorCode();
if (errorCode != EtherCATTypes.EcALState.NO_ERROR) {
System.out.printf(" 从站 %d: AL 错误 %s (0x%04X)%n",
slave.SlaveNum, errorCode, errorCode.value);
}
}
}
错误分类
使用 EtherCATTypes.classifyALError() 快速判断处理策略(参数为 AL 状态码 int):
EtherCATTypes.EcALState errorCode = slave.ErrorCode();
if (errorCode != EtherCATTypes.EcALState.NO_ERROR) {
EtherCATTypes.ALErrorCategory category =
EtherCATTypes.classifyALError(errorCode.value);
switch (category) {
case TRANSIENT:
// 瞬态错误(setState 内部已自动重试 3 次仍失败),通常需人工排查链路/电源
System.out.println("瞬态错误,已经过 SDK 内部重试仍未成功");
break;
case CONFIGURATION:
// 检查 PDO 映射、SM 配置
System.out.println("配置错误,请检查 PDO/SM 配置");
break;
case HARDWARE:
// 检查从站设备、线缆、电源
System.out.println("硬件错误,请检查从站设备");
break;
default:
break;
}
}
详细分类
完整的 AL 错误分类和常见错误码请参考 主站诊断 - AL 错误分类。
常见 AL Status Code
0x001E— 无效输入映射,检查 PDO 映射配置是否与从站支持的映射一致0x001D— 无效输出映射,检查 PDO 输出映射配置0x0017— 无效 SM 配置,检查 SyncManager 配置(大小、方向)0x001B— SM 看门狗超时,PDO 周期过慢或通信中断0x002D— 同步错误,DC 同步配置问题,检查 SYNC0 周期0x0032— DC 同步超时,DC 启动时间配置问题0x0003— 无效设备设置,耦合器无物理模块,或模块配置不匹配
事件驱动的异常处理
推荐通过事件监控异常,而非轮询:
MasterEvents events = master.Events();
// 状态降级检测
events.addStateChangedListener((oldState, newState) -> {
System.out.println("状态变化: " + oldState + " -> " + newState);
});
// 从站离线
events.addSlaveOfflineListener((si) ->
System.out.println("从站 " + si + " 离线"));
// PDO 丢帧
events.addPDOFrameLossListener((mi, g, c, t) -> {
if (c > 10)
System.out.printf("组 %d 严重丢帧: 连续 %d 帧%n", g, c);
});
// 紧急消息
events.addEmergencyEventListener((mi, si, ec, er, b, w1, w2) ->
System.out.printf("从站 %d 紧急消息: 0x%04X%n", si, ec));
自动日志
所有事件(PDO 周期回调除外)触发时系统均自动记录日志,无论是否订阅。详见 事件。
常见故障排查
create() 抛出异常
- 管理员权限不足 — 以管理员身份运行 JVM
java.library.path错误 — 确保Darra.Core.dll在路径中- DLL 加载失败 — 检查 VC++ 运行时是否安装(x64)
从站无法进入 OP
- PDO 映射不匹配 — 检查
slave.ErrorCode(),常见 0x001E/0x001D - ESI 版本不匹配 — 使用与固件版本对应的 ESI 文件
- DC 同步失败 — 检查 DC 配置,确认 SYNC0 周期合理
- SM 配置错误 — 检查 SyncManager 大小和方向
- 缺少启动参数 — 检查 Startup SDO 配置
通信不稳定
- 丢帧率高 — 检查网线质量、交换机端口、EMI 干扰
- 抖动大 — 安装 DarraRT 驱动,隔离 CPU 核心
- 偶尔超时 — 检查系统负载,关闭不必要的后台进程
- DC 同步偏差大 — 使用 DarraRT 驱动降低抖动