open62541开发:添加sqlite3 历史数据库

历史数据库在OPCUA 应用中十分重要,例如OPCUA 网关和OPCUA 汇聚服务器中都需要历史数据库功能。但是open62541 协议栈中仅包含了基于内存的历史数据库,在实际应用中是不够的。本博文讨论open62541 中添加sqlite3 为基础的历史数据库若干问题。

借鉴

Github上有一些open62541 添加sqlite 的项目的项目,在CSDN 上

学习open62541 --- [58] 使用数据库存储历史数据

的博文中,介绍了如何将sqlite 改成Linux 下的实现。它的项目在:

GitHub - nicolasr75/open62541_sqlite:

他的项目对我帮助很大,但是,它的sqlite 不是加载到open62541 的Plugin 中,而是单独地添加在应用程序的项目中的。 他将c程序和h 文件合在了一起,只有使用sqlite 历史数据时才会被include 并且编译。所有没有什么问题。我的项目是将open62541 安装到系统目录中的,所以希望将sqlite 结合到open61541 程序中。下面记录我的实现过程:

open62541 历史数据库的接口

在open62541 包这加入sqlite3

安装sqlite3 库

bash 复制代码
sudo apt -y install libsqlite3-dev
 

修改open62541 的cmake.txt

应用程序测试

相关推荐
恣艺1 小时前
Redis列表(List):实现队列/栈的利器,底层原理与实战
数据库·redis·list
秋难降2 小时前
零基础学习SQL(十一):SQL 索引结构|从 B+Tree 到 Hash,面试常问的 “为啥选 B+Tree” 有答案了
数据库·后端·mysql
代码的余温2 小时前
Linux内核调优实战指南
linux·服务器·数据库
almighty272 小时前
C# DataGridView表头自定义设置全攻略
数据库·c#·winform·datagridview·自定义表头
ljh5746491193 小时前
mysql 必须在逗号分隔字符串和JSON字段之间二选一,怎么选
数据库·mysql·json
论迹3 小时前
【Redis】-- 持久化
数据库·redis·缓存
getdu3 小时前
Redis面试相关
数据库·redis·面试
TDengine (老段)3 小时前
TDengine 选择函数 TOP() 用户手册
大数据·数据库·物联网·时序数据库·iot·tdengine·涛思数据
m0_694845573 小时前
教你使用服务器如何搭建数据库
linux·运维·服务器·数据库·云计算
okra-5 小时前
如何进行WEB安全性测试
数据库