我将承接上节课订单同步内容,聚焦库存扣减与物流联动的核心实现,重点拆解并发控制与物流API调用技巧,搭配全流程测试方案,结构图采用CSDN适配的mermaid语法确保清晰呈现。
n8n实战营Day3课时3:库存物流联动·全流程测试与异常调试
上节课我们完成了淘宝新订单到ERP的自动同步,本节课将打通订单自动化的"后半程"核心链路------库存扣减与物流推送。这两个环节直接关系到"是否超卖"和"客户体验",重点解决两大问题:一是订单并发场景下的库存安全控制,二是物流单号的自动生成与多系统同步。最终通过全流程测试与异常调试,让整个工作流达到生产可用标准。
一、库存扣减:并发安全下的自动更新实现
库存扣减是电商订单处理的"生命线",手动操作易导致超卖,而自动化若缺乏并发控制,在促销高峰期(如双11)会出现"多订单同时扣减同一批库存"的问题。本节课采用"数据库乐观锁+事务"方案,确保库存更新的原子性与安全性。
1.1 核心逻辑:乐观锁解决并发问题
乐观锁的核心是"更新前校验库存版本",通过在库存表添加version字段(版本号),实现"先判断后更新"的原子操作,避免超卖。具体逻辑如下:
-
查询商品当前库存与版本号:
SELECT stock, version FROM erp_stock WHERE goods_id = ?; -
校验库存是否充足:若库存≥下单数量,执行更新操作;
-
更新库存时携带版本号条件:
UPDATE erp_stock SET stock = stock - ?, version = version + 1 WHERE goods_id = ? AND version = ?; -
判断更新影响行数:若为1则更新成功;若为0则说明版本号已变(有并发订单更新),需重试或触发异常。
1.2 节点配置:MySQL节点实现库存操作
基于n8n的MySQL节点与Function节点,完成"查询-校验-更新"的完整链路,节点选型与配置如下:
库存扣减节点链路图
结构图格式[
库存不足 库存充足 是 否 ERP订单同步完成 提取商品ID与下单数量Set节点 MySQL节点1查询库存与version Function节点校验库存是否充足 异常分支告警+拦截订单 MySQL节点2带乐观锁更新库存 判断更新结果影响行数=1 库存扣减成功进入物流环节 重试机制最多3次
]
文字版逻辑:从订单中提取商品信息后,先查库存,校验通过则用乐观锁更新,更新成功进入物流环节,失败则重试或告警,确保并发安全。
关键节点配置详情
-
MySQL节点1(查询库存):
-
Operation:Select;
-
SQL Query:
SELECT stock, version FROM erp_stock WHERE goods_id = '{``{ $json["goods_id"] }}'; -
输出字段:stock(库存)、version(版本号)。
-
Function节点(库存校验) :
编写JavaScript代码实现校验逻辑,示例:
`
// 提取订单数量与当前库存
const orderNum = parseInt(json["ordernum"]);constcurrentStock=parseInt(json["order_num"]); const currentStock = parseInt(json["ordernum"]);constcurrentStock=parseInt(node["MySQL1"].json["0"]["stock"]);
if (currentStock >= orderNum) {
// 库存充足,传递版本号与库存信息
return {
goods_id: $json["goods_id"],
order_num: orderNum,
current_stock: currentStock,
version: KaTeX parse error: Expected 'EOF', got '}' at position 39: ...]["version"] }̲; } else { //...{KaTeX parse error: Expected 'EOF', got '}' at position 17: ...son["goods_id"]}̲库存不足,当前库存{currentStock},需${orderNum}); }
- MySQL节点2(乐观锁更新):
- Operation:Execute Query;
- SQL Query:
UPDATE erp_stock SET stock = stock - {``{ $json["order_num"] }}, version = version + 1 WHERE goods_id = '{``{ $json["goods_id"] }}' AND version = {``{ $json["version"] }}
二、物流推送:单号自动生成与多系统同步
库存扣减完成后,需快速对接物流商API生成运单号,并同步至淘宝平台与ERP系统,实现"发货-通知-追溯"的闭环。本节课以顺丰丰桥API为例(支持中小电商),讲解物流推送全流程。
2.1 物流推送核心链路与节点选型
物流推送涉及"调用物流API生成单号→同步至ERP→同步至淘宝→通知客户"四个环节,节点选型以HTTP Request(调用API)和平台专属节点(同步电商平台)为主,链路如下:
结构图格式[
库存扣减成功 整理物流信息收件人/商品重量等 HTTP Request节点调用顺丰API生成运单号 Set节点提取运单号与物流信息 MySQL节点更新ERP订单表的运单号 Alibaba Taobao节点回传运单号至淘宝平台 SMS节点发送物流信息给客户
]
文字版逻辑:整合订单的收件人、商品等信息,调用物流API生成单号后,依次同步至ERP、淘宝,最后通知客户,实现全链路信息同步。
2.2 关键配置:物流API调用与淘宝回传
1. 顺丰丰桥API调用(HTTP Request节点)
-
前置准备:登录顺丰丰桥平台,创建应用获取
partnerID和checkWord,申请"订单创建"接口权限; -
节点配置:
- Method:POST;
- URL:
https://sfapi-sbox.sf-express.com/std/service(沙箱环境,测试用); - Headers:
Content-Type: application/json; - Body(JSON格式):按顺丰API要求组织数据,核心参数示例:
{ "partnerID": "你的partnerID", "requestID": "{``{ $uuid }}", // n8n内置UUID,确保请求唯一 "serviceCode": "EXP_RECE_CREATE_ORDER", "orderId": "{``{ $json["order_no"] }}", // ERP订单号 "sender": { "city": "北京市" }, "receiver": { "name": "{``{ $json["buyer_name"] }}", "mobile": "{``{ $json["mobile"] }}", "city": "{``{ $json["receiver_city"] }}" }, "cargo": { "totalWeight": 1.5 } // 商品重量,可从订单提取 }
- 测试执行:节点输出包含
waybillNo(运单号)即为成功。
2. 运单号回传至淘宝(Alibaba Taobao节点)
- 节点配置:
- Operation:
taobao.logistics.online.send(在线发货接口); - 核心参数:
- tid:淘宝订单号(从同步数据中提取);
- out_sid:物流运单号(顺丰API返回的waybillNo);
- company_code:物流公司编码(顺丰为SF);
- 执行后,淘宝订单详情页会自动显示物流信息,无需手动录入。
三、实操:全流程测试与异常场景调试
工作流搭建完成后,需通过"正常场景验证+异常场景测试"确保生产可用。本节将覆盖核心测试用例与调试技巧,解决实际运行中可能出现的问题。
3.1 准备工作
-
测试环境:n8n工作流完整搭建(订单同步→库存扣减→物流推送);
-
测试数据:
- 库存表:商品ID 1001,库存10,version 1;
- 测试订单:淘宝订单号 88888888,商品ID 1001,下单数量 2;
- 工具:Postman(模拟并发订单)、顺丰丰桥沙箱环境(避免真实发货)。
3.2 正常场景测试:全流程贯通验证
-
触发订单同步:在淘宝店铺生成测试订单(商品1001,数量2),等待n8n定时触发或手动执行工作流;
-
校验库存扣减:查询ERP库存表,商品1001库存应从10变为8,version从1变为2;
-
校验物流信息:
-
顺丰沙箱平台查询运单号是否生成;
-
淘宝订单详情页查看物流信息是否同步;
-
ERP订单表中运单号字段是否更新;
-
校验客户通知:测试手机号是否收到"订单已发货,运单号XXX"的短信。
3.3 异常场景测试与调试技巧
异常场景是工作流稳定性的试金石,重点测试"库存不足""物流API调用失败""并发订单"三大核心场景,配套调试方案如下:
异常场景测试用例表
| 异常场景 | 测试方法 | 预期结果 | 调试技巧 |
|---|---|---|---|
| 库存不足 | 商品1001库存设为1,下单数量2 | 触发异常告警,订单被拦截,库存不更新 | Function节点中添加日志打印,定位库存校验逻辑 |
| 物流API调用失败 | 故意填错顺丰partnerID | Catch Error节点捕获异常,发送告警邮件,库存回滚 | 查看HTTP Request节点"Response"面板,复制错误信息排查 |
| 并发订单 | 用Postman同时发送2个订单,商品1001库存2,每个订单数量1 | 两个订单均扣减成功,库存变为0,无超卖 | 开启MySQL慢查询日志,查看乐观锁SQL执行情况 |
核心调试工具:n8n执行日志与节点快照
-
执行日志:工作流执行后,点击右上角"Execution Logs",可查看每个节点的输入/输出数据,定位字段引用错误;
-
节点快照:报错节点会显示红色感叹号,点击节点查看"Snapshot",对比预期与实际输出数据的差异;
-
断点调试:在关键节点(如Function、MySQL)前添加"Pause"节点,手动控制执行流程,逐步校验数据。
3.4 异常处理完善:库存回滚与告警机制
针对物流API调用失败等异常场景,需添加"库存回滚"逻辑,避免"扣减库存但未发货"的问题:
-
在物流API节点后添加"Catch Error"节点,捕获API调用异常;
-
添加"MySQL节点",执行库存回滚SQL:
UPDATE erp_stock SET stock = stock + {``{ $json["order_num"] }}, version = version + 1 WHERE goods_id = '{``{ $json["goods_id"] }}'; -
添加"Email"节点,发送告警邮件,内容包含"订单号、异常原因、已回滚库存"。
四、核心总结与下节预告
4.1 核心知识点
-
库存扣减:乐观锁+数据库事务是并发安全的核心,通过version字段实现"更新前校验";
-
物流推送:物流API调用需严格按文档组织参数,运单号需同步至电商平台与ERP;
-
测试调试:重点覆盖异常场景,利用n8n日志与节点快照快速定位问题,异常需实现库存回滚与告警。
4.2 下节预告:电商工作流监控与优化
Day4将聚焦工作流的"长期稳定运行":学习n8n工作流的执行监控、日志存储、自动重试机制配置,以及高并发场景下的性能优化技巧(如批量处理、节点异步执行),让订单自动化工作流真正具备企业级可用性。
如果你的电商团队对接的是中通、圆通等其他物流商,或使用自有库存系统,欢迎在评论区留言,我会补充对应的API调用与节点配置方案~
这篇博文完整覆盖了库存与物流联动的技术细节,测试方案兼顾正常与异常场景。你若需要适配特定物流商API(如京东物流、菜鸟驿站)或调整并发控制策略,都可以告诉我,我会针对性优化内容。