通讯网关软件024——利用CommGate X2Access实现Modbus TCP数据转储Access

本文介绍利用CommGate X2ACCESS实现从Modbus TCP设备读取数据并转储至ACCESS数据库。CommGate X2ACCESS是宁波科安网信开发的网关软件,软件可以登录到网信智汇(http://wangxinzhihui.com)下载。

【案例】如下图所示,实现从Modbus TCP设备读取数据并转储至ACCESS数据库。

【解决方案】在Access宿主机上安装CommGate X2ACCESS软件,与SCADA/PLC/设备Modbus TCP Slave采用以太网通讯。

  1. ACCESS数据表结构要求,如下:
  • 至少要求具备Id、name、value三个字段。
  • name:标签名称,字符类型
  • value:数值,可以是字符类型或浮点类型
  • state:1表示好值 0表示坏值
  • time:不是必须,可以是datetime或bigint
  • 以上字段名称如不是Id、name、value、state、time,需要在以下配置文件进行字段名称的配置
  1. Modbus TCP通讯调试:在网关机上运行modscan,与SCADA/PLC/设备进行Modbus TCP通讯调试。通讯正常后,记下通讯参数。

2.配置X2ACCESS 出口端参数:在X2ACCESS安装Ini目录下编辑X2ACCESS.ini,修改出口端参数。

[OUT]

;输入源类型:ACCESS,不做修改
Type=ACCESS

;数据库密码
Pwd=123456

;数据库路径
DB=F:\Program_KA3\CommGate\bin\RealTime.mdb

;连接串,定义连接串,以连接串信息为准,以上用户密码等信息配置忽略
ConnectStr=Provider=Microsoft.Jet.OLEDB.4.0;Jet OLEDB:Database password=123456;Data Source=F: 
\Program_KA3\CommGate\bin\RealTime.mdb

;读取数据的SQL语句,如果不设置的话,将由以下字段名自动构造
;表中至少包含name,value字段
;state字段不是必须的,没有state字段时,必须构造1个虚拟state字段,如select name, value, 1 as state from snapshot
;State值 = 1 好值  =0 坏值

ReadSQL=select name1, value1, state1, time1 from snapshot

;定义Name字段名,默认为name
NameField = name1

;定义Value字段名,默认为value
ValueField = value1

;定义State字段名,默认为state
StateField = state1

;定义Time字段名,可以不定义,默认为空,表示没有Time字段
TimeField = time1

[IN]
;输入端配置文件名,不含后缀
INI = ModbusTcp

;通讯类型
Type=

3.配置X2ACCESS 入口端参数:在X2ACCESS安装目录Ini下编辑ModbusTcp.ini,按照刚才记下的通讯参数修改入口端参数。

[IN]

;通讯类型Modbus TCP,不做修改
Type=MODBUS_TCP

;modbus tcp server ip
Host=127.0.0.1

;modbus tcp server 端口
Port=502

;从设备地址
DeviceID=1

;通讯超时,单位ms
Timeout=300

;读寄存器间隔时间,单位ms,一般不做修改
ReadDevTime=50

;浮点/双精度字节顺序类型  0:ABCD/ABCDEFGH 1:CDAB/GHEFCDAB 2:DCBA/HGFEDCBA 3:BADC/BADCFEHG
SwapFloat=2

;整型/长整型字节顺序类型  0:ABCD/ABCDEFGH 1:CDAB/GHEFCDAB 2:DCBA/HGFEDCBA 3:BADC/BADCFEHG
SwapInt=1

4.标签配置:在X2ACCESS安装目录下编辑X2ACCESS.xls,配置标签。

5.运行X2ACCESS.exe,启动网关。

6.ACCESS数据查看:用ACCESS调试工具查看写入的数据是否正确。

7.细配置说明见《X2ACCESS V4使用手册》。

更多通信资源请登录网信智汇(http://wangxinzhihui.com)。

相关推荐
月落星还在1 小时前
Redis 的过期策略与键的过期时间设置
数据库·redis·bootstrap
cg50174 小时前
MySQL数据库复杂的增删改查操作
数据库·mysql
虾球xz5 小时前
游戏引擎学习第147天
数据库·学习·游戏引擎
向上的车轮6 小时前
什么是时序数据库?有哪些时序数据库?常见的运用场景有哪些?
数据库·时序数据库
SuperW7 小时前
EPS8266远端固定UDP传输
网络·网络协议·udp
岱宗夫up7 小时前
【Python】Django 中的算法应用与实现
数据库·python·opencv·django·sqlite
比花花解语7 小时前
使用数据库和缓存的时候,是如何解决数据不一致的问题的?
数据库·缓存·数据一致性
YGGP8 小时前
Redis篇:基础知识总结与基于长期主义的内容更新
数据库·redis·缓存
KINICH ahau8 小时前
数据库1-2章
数据库·oracle
我想吃烤肉肉8 小时前
leetcode-sql数据库面试题冲刺(高频SQL五十题)
数据库·sql·leetcode