iperf_client.lua 3.1 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394
  1. --[[
  2. @module iperf_client
  3. @summary iperf客户端模式测试模块
  4. @version 1.0
  5. @date 2025.10.29
  6. @author 拓毅恒
  7. @usage
  8. 本模块演示如何初始化CH390以太网并启动iperf客户端模式进行测试。
  9. 适用于路由器连接场景,设备通过DHCP从路由器获取IP地址。
  10. 1、初始化SPI接口连接CH390
  11. 2、设置CH390驱动和网络参数
  12. 3、配置从路由器获取IP地址
  13. 4、连接到指定的iperf服务器并进行测试
  14. 本文件没有对外接口,直接在 main.lua 中 require "iperf_client" 即可加载运行。
  15. ]]
  16. -- 引入必要的模块
  17. local netdrv_eth_spi = require "netdrv_eth_spi"
  18. -- 配置服务器IP地址(需要根据实际服务器IP进行修改)
  19. local SERVER_IP = "192.168.1.3" -- 这里需要修改为实际的服务器IP地址
  20. -- iperf测试报告处理函数
  21. local function iperf_report_handler(bytes, ms_duration, bandwidth)
  22. -- 转换为Mbps显示
  23. local bandwidth_mbps = bandwidth / 1024 / 1024 * 8
  24. log.info("iperf报告", string.format("数据量: %d bytes, 持续时间: %d ms, 带宽: %.2f Mbps", bytes, ms_duration, bandwidth_mbps))
  25. end
  26. -- iperf客户端任务
  27. local function iperf_client_task()
  28. log.info("iperf测试", "等待网络初始化完成...")
  29. -- 等待IP地址获取成功
  30. log.info("iperf测试", "等待获取IP地址...")
  31. -- 设置IP获取超时
  32. local ip_wait_count = 60
  33. while true do
  34. local ipv4 = socket.localIP(socket.LWIP_USER1)
  35. if ipv4 and ipv4 ~= "0.0.0.0" then
  36. log.info("iperf测试", "IP获取成功:", ipv4)
  37. break
  38. end
  39. -- 超时检查
  40. if ip_wait_count <= 0 then
  41. log.error("iperf测试", "获取IP地址超时")
  42. return
  43. end
  44. ip_wait_count = ip_wait_count - 1
  45. sys.wait(1000)
  46. end
  47. -- 等待以太网连接
  48. while not socket.adapter(socket.LWIP_USER1) do
  49. sys.wait(100)
  50. end
  51. log.info("iperf测试", "以太网连接状态: 已连接")
  52. -- 启动客户端模式,连接到指定服务器
  53. log.info("iperf测试", "启动客户端模式")
  54. log.info("iperf测试", "连接到服务器IP:", SERVER_IP, "端口: 5001")
  55. -- 连接服务器
  56. iperf.client(socket.LWIP_USER1, SERVER_IP, 5001)
  57. -- 订阅iperf测试报告事件
  58. sys.subscribe("IPERF_REPORT", iperf_report_handler)
  59. log.info("iperf测试", "测试开始")
  60. -- 设置测试循环次数,共测试2分钟
  61. local test_count = 24
  62. while test_count > 0 do
  63. -- 等待IPERF_REPORT事件,超时时间5秒
  64. local report_received = sys.waitUntil("IPERF_REPORT", 5000)
  65. if report_received then
  66. -- 如果收到报告事件,退出循环
  67. log.info("iperf测试", "收到报告,结束测试")
  68. break
  69. else
  70. -- 如果超时,继续测试
  71. test_count = test_count - 1
  72. log.info("iperf测试", "测试进行中...")
  73. end
  74. end
  75. -- 测试结束
  76. log.info("iperf测试", "测试结束,关闭客户端")
  77. iperf.abort()
  78. end
  79. -- 执行iperf客户端模式测试
  80. sys.taskInit(iperf_client_task)