xxhuangyan 2024-08-25 21:53 采纳率: 50%
浏览 2
已结题

go modbu tcp


func main() {
    provider := modbus.NewTCPClientProvider("192.168.1.100:502", modbus.WithTCPTimeout(time.Second*3), modbus.WithEnableLogger())
    client := modbus.NewClient(provider)
    if err := client.Connect(); err != nil {
        log.Fatalf("modbus连接失败:%v", err)
        return
    }

    defer func() {
        if err := client.Close(); err != nil {
            log.Println("modbus关闭失败:", err)
        }
    }()

    for {
        results, err := client.ReadInputRegisters(1, 0, 2)
        log.Println(results)
        if err != nil {
            log.Printf("modbus读取失败:%v", err)
            continue
        }
        log.Printf("设备%v, 温度: %v", 1, results[0])
        log.Printf("设备%v, 湿度: %v", 1, results[1])
        log.Printf("客户端状态: %v\n", &client)
    }
}

为什么我这样会出现tcp 192.168.1.200:43477->192.168.1.100:502: i/o timeout但是本地使用modbus 调试工具是可以得到值的

  • 写回答

1条回答 默认 最新

  • 吃不了席 2024-08-25 21:54
    关注

    以下回复参考:皆我百晓生券券喵儿等免费微信小程序作答:

    这个问题可能是由于网络连接不稳定或者服务器端没有正确响应导致的。你可以尝试以下方法来解决这个问题:

    1. 检查你的网络连接是否稳定,确保你的设备和服务器之间的网络连接没有问题。

    2. 增加TCP超时时间。在创建TCP客户端提供者时,你可以增加TCP超时时间,例如将其设置为5秒:

    provider := modbus.NewTCPClientProvider("192.168.1.100:502", modbus.WithTCPTimeout(5*time.Second), modbus.WithEnableLogger())
    
    1. 检查服务器端是否正确响应。你可以使用Wireshark等网络抓包工具来检查服务器端是否正确响应了客户端的请求。如果没有正确响应,你需要检查服务器端的实现。

    2. 如果问题仍然存在,你可以尝试使用其他Modbus库来实现相同的功能,以排除库本身的问题。

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

问题事件

  • 系统已结题 9月6日
  • 已采纳回答 8月29日
  • 创建了问题 8月25日

悬赏问题

  • ¥15 如何在vue.config.js中读取到public文件夹下window.APP_CONFIG.API_BASE_URL的值
  • ¥50 浦育平台scratch图形化编程
  • ¥20 求这个的原理图 只要原理图
  • ¥15 vue2项目中,如何配置环境,可以在打完包之后修改请求的服务器地址
  • ¥20 微信的店铺小程序如何修改背景图
  • ¥15 UE5.1局部变量对蓝图不可见
  • ¥15 一共有五道问题关于整数幂的运算还有房间号码 还有网络密码的解答?(语言-python)
  • ¥20 sentry如何捕获上传Android ndk 崩溃
  • ¥15 在做logistic回归模型限制性立方条图时候,不能出完整图的困难
  • ¥15 G0系列单片机HAL库中景园gc9307液晶驱动芯片无法使用硬件SPI+DMA驱动,如何解决?