go之goburrow/modbus 学习

goburrow/modbus 是一个用Go语言实现的Modbus协议库,提供了Modbus主机(Master)和从机(Slave)的实现,支持两种主要的Modbus传输模式:Modbus TCP和Modbus RTU。

功能介绍

1. 支持的传输模式
  • Modbus TCP : 这是基于TCP/IP的Modbus通信协议,通常用于以太网或Wi-Fi连接的设备。goburrow/modbus库通过TCPClientHandler来处理Modbus TCP通信。

  • Modbus RTU : 这是基于串行通信(如RS-232、RS-485)的Modbus协议,通常用于工业自动化环境中的设备。goburrow/modbus库通过RTUClientHandler来处理Modbus RTU通信。

2. Modbus主机功能(Master)

作为Modbus主机,goburrow/modbus库支持多种Modbus功能码,让你能够与Modbus从机设备进行读写操作:

  • 读写寄存器和线圈
    • ReadCoils(address, quantity) - 读取线圈状态(功能码01)
    • ReadDiscreteInputs(address, quantity) - 读取离散输入状态(功能码02)
    • ReadHoldingRegisters(address, quantity) - 读取保持寄存器值(功能码03)
    • ReadInputRegisters(address, quantity) - 读取输入寄存器值(功能码04)
    • WriteSingleCoil(address, value) - 写单个线圈状态(功能码05)
    • WriteSingleRegister(address, value) - 写单个保持寄存器值(功能码06)
    • WriteMultipleCoils(address, quantity, value) - 写多个线圈状态(功能码15)
    • WriteMultipleRegisters(address, quantity, value) - 写多个保持寄存器值(功能码16)
3. Modbus从机功能(Slave)

goburrow/modbus库主要提供Modbus主机功能,默认并不包含从机功能的实现。要实现从机功能,通常需要手动处理Modbus请求并响应。虽然goburrow/modbus没有直接的从机实现,但可以通过使用底层的TCP或串口库自行处理从机请求。

4. 错误处理
  • goburrow/modbus 提供了基本的错误处理机制。如果在发送Modbus请求或接收响应时出现错误,会返回一个带有错误信息的error对象。
5. 连接管理
  • 连接管理 :提供了Connect()Close()方法,用于与Modbus设备的连接和断开连接。
  • 自动重连:通过控制连接的生命周期,支持在连接断开时重新连接的逻辑。
6. 高级功能
  • 超时设置 :允许通过Timeout参数设置读写操作的超时时间。
  • 从机ID配置 :在Modbus通信中,SlaveId用来指定目标从机的ID。每次操作时可以指定不同的从机ID。
  • 数据帧自定义goburrow/modbus 允许你构建自定义的Modbus数据帧,并直接发送/接收原始帧数据。
7、示例
使用Modbus TCP客户端

以下是一个简单的Modbus TCP客户端示例,用于读取从站设备的保持寄存器值:

go 复制代码
package main

import (
    "fmt"
    "github.com/goburrow/modbus"
)

func main() {
    // 创建Modbus TCP客户端
    handler := modbus.NewTCPClientHandler("192.168.1.1:502")
    handler.Timeout = 10 * time.Second
    handler.SlaveId = 1

    // 连接到Modbus服务器
    err := handler.Connect()
    if err != nil {
        panic(err)
    }
    defer handler.Close()

    client := modbus.NewClient(handler)

    // 读取保持寄存器(功能码03),从寄存器地址0开始,读取2个寄存器
    results, err := client.ReadHoldingRegisters(0, 2)
    if err != nil {
        panic(err)
    }

    fmt.Printf("Received: %x\n", results)
}
使用Modbus RTU客户端

如果你使用的是Modbus RTU(通常通过串口通信),可以使用如下代码:

go 复制代码
package main

import (
    "fmt"
    "github.com/goburrow/modbus"
    "time"
)

func main() {
    // 创建Modbus RTU客户端
    handler := modbus.NewRTUClientHandler("/dev/ttyUSB0")
    handler.BaudRate = 19200
    handler.DataBits = 8
    handler.Parity = "N"
    handler.StopBits = 1
    handler.SlaveId = 1
    handler.Timeout = 10 * time.Second

    // 打开串口连接
    err := handler.Connect()
    if err != nil {
        panic(err)
    }
    defer handler.Close()

    client := modbus.NewClient(handler)

    // 读取保持寄存器(功能码03),从寄存器地址0开始,读取2个寄存器
    results, err := client.ReadHoldingRegisters(0, 2)
    if err != nil {
        panic(err)
    }

    fmt.Printf("Received: %x\n", results)
}
注意事项
  • 超时设置 : handler.Timeout 参数设置的是连接和读写操作的超时时间,根据实际网络情况调整。
  • 串口参数配置: 如果使用Modbus RTU,请确保串口参数(波特率、数据位、校验位、停止位)与设备匹配。
相关推荐
GIS数据转换器1 分钟前
GIS+大模型助力安全风险精细化管理
大数据·网络·人工智能·安全·无人机
让学习成为一种生活方式17 分钟前
植物中验证蛋白相互作用的Pull-down和Co-IP技术--文献精读181
网络·网络协议·tcp/ip
普普通通的南瓜26 分钟前
IP证书在关键信息基础设施安全防护中的实践与挑战
网络·数据库·网络协议·tcp/ip·安全·ssl
今天你TLE了吗2 小时前
Stream流学习总结
java·学习
讨厌下雨的天空2 小时前
网络基础
网络·1024程序员节
0和1的舞者3 小时前
《网络编程核心概念与 UDP Socket 组件深度解析》
java·开发语言·网络·计算机网络·udp·socket
华普微HOPERF3 小时前
Matter协议,如何赋能智能家居构建跨生态的互操作网络?
网络·智能家居
河南博为智能科技有限公司4 小时前
动环监控终端-守护变电站安全运行的智能核心
运维·服务器·网络·物联网
无心水4 小时前
【Python实战进阶】5、Python字符串终极指南:从基础到高性能处理的完整秘籍
开发语言·网络·python·字符串·unicode·python实战进阶·python工业化实战进阶
Top`5 小时前
两个服务之间传递的数据本质上是字节码(Byte Stream)
网络