网站首页 > 技术教程 正文
前 言
SIMATIC WinCC作为行业内非常著名的SCADA软件,是西门子最经典的过程监视系统,实现了自动化系统与IT系统之间的互联互通。WinCC能为工业领域提供完备的监控与数据采集(SCADA)功能,其功能随着版本的不断升级也不断更新完善。
WinCC除了能完成强大的界面设计,还支持相对完备的脚本编程,其脚本为基于ANSI-C标准的C和VBScript。具体编程可参考官方提供的编程手册。但是在项目实际开发过程中,基于数据共享的需求,经常还是会碰到多语言开发的问题,即需要架构起WinCC与高级语言(C++、C#、Java、Python... ...)的桥梁。
程序之间的数据通信有多种方式,不仅仅局限于图中列举的几种方式
本文主要介绍WinCC与高级语言间如何构建一种相对高效、实时的数据共享通道,采用内存数据库Redis作为共享数据区,介绍如何从WinCC访问Redis 数据库。因为高级语言访问Redis数据库有基本的访问函数。
Redis数据库首先简单介绍一下什么是Redis数据库和其特点。Redis是一种key-value 存储系统,是当前互联网世界最为流行的 NoSQL 数据库,开源免费,提供了 Java,C/C++,C#,PHP 等客户端,使用方便。主要应用于内容缓存和处理大量数据的高访问负载。Redis 具备一定持久层的功能,也可以作为一种缓存工具。对于 NoSQL 数据库而言,作为持久层,它存储的数据是半结构化的,这就意味着计算机在读入内存中有更少的规则,读入速度更快。Redis的操作主要在内存里,其有如下主要特点:1)响应快速Redis 响应非常快,每秒可以执行大约 110 000 个写入操作,或者 81 000 个读操作,其速度远超数据库。2)支持 6 种数据类型分别是字符串、哈希表、列表、集合、可排序集合和基数。尤其是哈希表可以存储对像,在Python语言里对应dict,其他高级语言对应JSON对像,列表对应于Python的list,方便开发。3)操作原子性所有Redis的操作都是原子的,从而确保当不同程序同时访问Redis服务器时,得到的是最新值。
Windows中安装Redis Server
在Redis数据库一般情况下安装在Linux下居多,好在微软也编译了Windows的安装包,只是维护到V3.2版本就停止了。具体下载地址见https://github.com/microsoftarchive/redis/releases/ 。
下载Zip包解压,得到可执行程序,运行Redis-server.exe即可。
1)执行redis-server.exe redis.windows.conf,启动Redis服务
2)执行redis-cli.exe 默认访问本机Redis服务
测试ping 命令,返回PONG,表示数据库服务正常。
WinCC访问Redis方法
WinCC访问SQL等数据库采用的主要是ODBC来访问,可Redis是非关系型数据库,不便采用ODBC方式。本文介绍一种WinCC访问Redis的方法,步骤如下:
1)下载redis-com-client组件库:
加入剑指工控技术群,咨询群管理员百度网盘下载链接和验证码。
2)解压后进入目录,执行如下命令,向Windows注册一个redis-com-client组件;
`C:\Windows\Microsoft.NET\Framework64\v4.0.30319\RegAsm.exe /tlb redis-com-client.dll /tlb:redis-com-client.tlb /codebase`
3)在WinCC里使用VBScript调用redis-com-client组件方法
4)测试
向Redis数据库写入一个哈希字段,键SEC1,字段名Humidity,数据为66.88;同时从Redis读取一个字符串对象,键Temperature,读取的值写入到WinCC的内部变量名为Temperature的标签。
脚本执行前:
脚本执行后:
至此完成了WinCC与Redis数据库的双向操作,将Redis作为缓冲区,借由其为内存数据库的优势,充分发挥Redis的读写高速、数据对像化方便、访问原子性的特点,构建与其他高级语言的通信的桥梁。
小 结
本文出发点是基于WinCC强大的组态功能基础上,通过Redis内存数据库,构建与其他高级语言协同编程的一种方法,充分发挥高级语言处理数据功能强、定制客户需求方便的优势,实现系统互补。希望能抛砖引玉,同探讨,共提升。
猜你喜欢
- 2024-10-18 SOLIDWORKS PDM客户端安装问题总结
- 2024-10-18 2021届中考总复习,圆的知识重难点综合和中考考点归纳总结
- 2024-10-18 SQL Server错误18456:解决方案(sql2008r2错误18456)
- 2024-10-18 老董精心编写-WINCC组态软件生成EXCEL报表详细脚本
- 2024-10-18 一步一步教你,在iFix中如何将数据记录通过ODBC保存到SQL SERVER
- 2024-10-18 SQL学习篇 | 对比Excel Power Query学习SQL
- 2024-10-18 条码软件如何通过ODBC数据源访问SQLServer(二)
- 2024-10-18 Access配置odbc数据源连接ORACLE数据库
- 2024-10-18 GBASE南大通用GBase 8a ODBC的安装文件
- 2024-10-18 oracle怎么通过odbc进行异构库跨连SQL server
你 发表评论:
欢迎- 最近发表
-
- Win11学院:如何在Windows 11上使用WSL安装Ubuntu
- linux移植(Linux移植freemodbus)
- 独家解读:Win10预览版9879为何无法识别硬盘
- 基于Linux系统的本地Yum源搭建与配置(ISO方式、RPM方式)
- Docker镜像瘦身(docker 减小镜像大小)
- 在linux上安装ollama(linux安装locale)
- 渗透测试系统Kali推出Docker镜像(kali linux渗透测试技术详解pdf)
- Linux环境中部署Harbor私有镜像仓库
- linux之间传文件命令之Rsync傻瓜式教程
- 解决ollama在linux中安装或升级时,通过国内镜像缩短安装时长
- 标签列表
-
- 下划线是什么 (87)
- 精美网站 (58)
- qq登录界面 (90)
- nginx 命令 (82)
- nginx .http (73)
- nginx lua (70)
- nginx 重定向 (68)
- Nginx超时 (65)
- nginx 监控 (57)
- odbc (59)
- rar密码破解工具 (62)
- annotation (71)
- 红黑树 (57)
- 智力题 (62)
- php空间申请 (61)
- 按键精灵 注册码 (69)
- 软件测试报告 (59)
- ntcreatefile (64)
- 闪动文字 (56)
- guid (66)
- abap (63)
- mpeg 2 (65)
- column (63)
- dreamweaver教程 (57)
- excel行列转换 (56)
本文暂时没有评论,来添加一个吧(●'◡'●)