PLC-Recorder通过Modbus TCP/Modbus RTU转换器实现RS-485总线设备采集的方法

目录

1、通过从站地址参数来进行区分

2、通过变量地址进行区分

3、通过端口号进行区分

4、小结


PLC-Recorder是一款基于以太网的高速数据采集软件,用于故障诊断、工艺过程数据连续记录等。对于现场大量存在的通过RS-485进行通讯的Modbus RTU设备,该如何采集呢?可以通过Modubs RTU到Modbus TCP的协议转换器来进行采集。

目前,国内这类协议转换器的品牌很多,价格已经很低,基本在500元以下了,只要进行一些简单配置,就可以实现众多Modbus RTU设备的数据采集。

一般来说,一个协议转换器可以通过RS-485总线同时与多个从站通讯,因此,TCP侧就需要知道从站的站点地址。对此,不同的厂家有不同的解决方案,下面简述其中的3种方案,应该能涵盖大部分的协议转换器了。

1、通过从站地址参数来进行区分

Modbus TCP电文也支持从站地址,因此,只要给定从站地址,就可以实现从站区别。比如,北辰的BCNet-MB模块就采用了这种方式。在配置好模块的IP地址和端口(一般是502)、485侧的网络参数后,即可进行通讯。模块的配置示意图如下:

PLC-Recorder侧的配置如下,其中的站点号就是RTU从站的站号:

这种方案下,我们需要为每个从站建一个通道,比较浪费通道资源。

2、通过变量地址进行区分

以大连德嘉的协议转换器为例(注意:它也支持方案1),如果需要采集多个从站,则协议转换器里启用选择从站的最大数量:

 然后将站号放在变量地址里,规则如下:

1个从站:正常设置,不需要区分。

最多7个从站,将第5位作为从站号:

最多66个从站,将第4、5位作为站号:

PLC-Recorder里配置变量地址时,第6位为功能码(地址区间)。如果选择了“7个从站”,从站设备寄存器地址为03功能码(4xxxx),实际地址为20(十进制)。
1号从站寄存器地址定义为400020;
2号从站寄存器地址定义为410020;
3号从站寄存器地址定义为420020;
……
建变量时可能要地址+1,那就定义为400021、410021、420021……

 这种方案下,我们仅需要一个通道,就可以完成所有从站的采集,还是有一定的优越性的。

3、通过端口号进行区分

有网友用有人的DR302进行从站数据采集的时候,就需要通过端口号来区分从站,在协议转换器里进行设置。这种方案下,我们也需要为每个从站建立一个通道。

4、小结

综上所述,国内协议转换器的品牌很多,价格已经很低,不像以前,只能从国外采购协议转换器,动辄上万元。朋友们可以借助这些协议转换器,方便地实现PLC-Recorder对于Modbus RTU设备的数据采集了。


2022年4月1日

  • 1
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Vue.js是一款流行的JavaScript框架,可用于构建Web应用程序。要在Vue.js应用程序中实现录音功能,您可以使用第三方JavaScript库JS Audio Recorder。该库提供了一个简单易用的API,可用于录制音频,并生成波形图。 要生成波形图,您可以使用WaveSurfer.js库。它是一个用于Web音频可视化的JavaScript库,可用于显示音频波形图。 以下是一些步骤来使用JS Audio Recorder和WaveSurfer.js实现Vue.js录音功能并生成波形图: 1.安装JS Audio Recorder和WaveSurfer.js 您可以使用npm安装这些库: ``` npm install jrecorder wavesurfer.js ``` 2.在Vue.js应用程序中引入库 您需要在Vue.js组件中引入这些库: ```javascript import JRecorder from 'jrecorder'; import WaveSurfer from 'wavesurfer.js'; ``` 3.创建录音器对象 您可以创建一个JS Audio Recorder对象来处理录音。您需要指定配置选项,如音频格式、采样率和位深度等。例如: ```javascript const recorder = new JRecorder({ workerPath: '/path/to/recorderWorker.js', encoding: 'mp3', numChannels: 2, sampleRate: 44100, bitRate: 192000, bufferSize: 16384, onAnalysed: function(data) { // 处理波形数据 } }); ``` 4.创建波形图对象 您可以使用WaveSurfer.js创建波形图对象。您需要指定DOM元素和配置选项。例如: ```javascript const waveform = WaveSurfer.create({ container: '#waveform', waveColor: '#888', progressColor: '#333' }); ``` 5.开始录音 当用户点击“录音”按钮时,您可以调用recorder.startRecording()来开始录音。同时,您可以调用waveform.recordStart()来开始绘制波形图。 ```javascript recorder.startRecording(); waveform.recordStart(); ``` 6.停止录音 当用户点击“停止”按钮时,您可以调用recorder.stopRecording()来停止录音。同时,您可以调用waveform.recordStop()来停止绘制波形图。最后,您可以调用waveform.loadBlob(blob)来加载录制的音频数据并绘制完整的波形图。 ```javascript recorder.stopRecording(function(blob) { waveform.recordStop(); waveform.loadBlob(blob); }); ``` 以上是实现Vue.js录音功能并生成波形图的基本步骤。如果您需要更多详细信息,请参考JS Audio Recorder和WaveSurfer.js的官方文档。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值