iNeuOS工业互联平台,iNeuKernel(物联网核心组件)远程控制标准化设计与实现。发布v2.3版本。
目 录
1. 概述... 2
2. 平台演示... 2
3. 控制端与iNeuKernel的交互协议... 3
4. 设备驱动实现控制业务... 4
5. 应用效果... 9
5.1 CS客户端... 9
5.2 BS浏览器... 9
5.3 Linux环境测试... 10
5.4 视频应用效果... 10
>>iNeuKernel v2.3版本下载:https://pan.baidu.com/s/1nxpnC7FazBBVyK9zUFgjyg
1. 概述
2019年6月,iNeuOS发布第一个版本以来,实际合作的客户和在谈合作的客户,对于云端控制或云端修改参数的需求比较多,基本上是共识。将来5G的发展和应用,云端控制将是一个常态,在iNeuOS的规划中已经作为一项重要工作。之所以没有早期开发云端控制部分,是因为我们所在的工业领域(煤炭、钢铁、化工、电力等)是重工业,与互联网传输数据都有严格的限制,更不可能让云端控制,另外涉及到安全问题。
大部分云端控制的需求涉及行业一般为环保、农业、电工装备等,业务需求一般是远程修改参数和控制一些开关状态,但是这些操作不会带来致命事故,更多的是从远程运维角度考虑的需求。
现在iNeuKernel(设备容器)物联网核心组件,已经具备了远程控制服务功能,支持终端设备或软件以Socket或WebSocket通道协议,通过标准的文本协议与硬件或传感进行交互,实现远程修改参数和控制的目的。后续会把这项功能集成到iNeuView(Web组态)视图建模,可以通过组态页面操作实现远程控制。
参见以前的文章:
《4种通讯模式机制》
2. 平台演示
在线演示:http://demo.ineuos.net (注:服务器比较慢,请耐心等待。自已注册用户,体验系统功能)
视频演示:http://www.ineuos.net/video/iNeuOS%20and%20app.mp4
驱动开发:http://www.ineuos.net/index.php/products/ineukernel-15.html (v2.1版本)
手机APP:http://demo.ineuos.net/app/ineuos_app.apk
3. 控制端与iNeuKernel的交互协议
控制端可以理解为iNeuView组态,控制操作通过交互协议与后台的iNeuKernel进行交互,进一步与设备驱动交互,对设备进行控制操作,当然其他终端的操作链路也是这样的。示意,如下图:

交互协议充分考虑了系统命令和设备命令两种情况,一个是对后台服务进行远程控制,一个是对设备进行控制,综合完成远程运维业务需求。示意,如下图:

4. 设备驱动实现控制业务
以Modbus RTU通讯协议为例,实现远程控制业务需求。IRunDevice接口有一个RunServiceConnector函数接口接收控制端发来的交互信息,交互信息是一个DevicePacket协议包。
注:具体代码事例,可以加物联网&大数据技术群:54256083,找群主。
(1)DevicePacket设备协议包转换成JSON格式
"DevicePacket": {
"OperationCode": "",
"DeviceId": "92b2306385f749d494a9b24f469cac87",
"DeviceName": "Modbus",
"Desc": "",
"DeviceFrames": [
{
"TagId": "79be2b1e790f4c06873a8446bca755ea",
"TagName": "tag1",
"DataType": "int",
"Value": "true",
"FrameId": "",
"OperationType": "setack",
"Code": "",
"Desc": "淇敼鎴愬姛",
"Time": "2020-02-06T20:21:27.0322772+08:00"
}
]
}
(2)RunServiceConnector函数接口接收设备协议包
/// <summary>
/// 与服务(Service)交互使用的接口,与service.OnServiceConnector配合使用。
/// </summary>
/// <param name="fromService"></param>
/// <param name="toDevice"></param>
/// <param name="asyncService"></param>
/// <returns></returns>
public override IServiceConnectorCallbackResult RunServiceConnector(IFromService fromService, IServiceToDevice toDevice, AsyncServiceConnectorCallback asyncService)
{
if(!(toDevice.Object is DevicePacket))
{
OnDeviceRuningLog("RunServiceConnector 接收到的为非 DevicePacket 对象");
return null;
}
//设置优先调用此设备驱动
this.DevicePriority = DevicePriority.Priority;
//接收过来的设备协议包
this._devicePacket = (DevicePacket)toDevice.Object;
//异步返回操作结果,把操作最终的结果反馈给代理服务,最终通知操作端
this._asyncServiceConnectorCallback = asyncService;
//设置为当前为接收状态
this._sendCommandState = SendCommandState.Received;
OnDeviceRuningLog("已经接收到命令交换信息,正在准备下发命令......");
return new ServiceConnectorCallbackResult(true, null);
}
(3)GetConstantCommand()函数接口获得下发控制命令
if (_sendCommandState == SendCommandState.Received) //发送命令
{
#region 构建发送命令
if (_devicePacket != null)
{
#region
_sendCommandState = SendCommandState.ReadySending;
foreach (DeviceFrame df in _devicePacket.DeviceFrames)
{
ITag tag = tags.Where(t => t.TagId == df.TagId && t.TagName == df.TagName).FirstOrDefault();
if (tag != null)
{
IModbusMessage requestMsg = null;
byte[] reqeustBytes = null;
switch (tag.Function)
{
case 0x01: //线圈,bool值
reqeustBytes = _modbusRtuMaster.BuildWriteSingleCoilCommand(byte.Parse(tag.SlaveId), ushort.Parse(tag.Address), bool.Parse(df.Value), out requestMsg);
break;
case 0x03: //保持寄存器,数值
reqeustBytes = _modbusRtuMaster.BuildWriteSingleRegisterCommand(byte.Parse(tag.SlaveId), ushort.Parse(tag.Address), ushort.Parse(df.Value), out requestMsg);
break;
default:
OnDeviceRuningLog("没有找到可写入命令的标签配置");
break;
} if (reqeustBytes != null)
{
requestList.Add(new RequestInfo(reqeustBytes, new SendObject(requestMsg, tag)));
}
}
}
_sendCommandState = SendCommandState.Sending;
#endregion
}
else
{
_sendCommandState = SendCommandState.None;
}
#endregion
}
(4)Communicate接收控制命令返回结果
byte[] revData = info.Data;
IModbusMessage requestMessage = _sendObject.ModbusMessage;
ITag tag = _sendObject.Tag;
//用于验证修改值返回数据
bool modiftyData = false; //是否修改返回数据
bool validate = true; //验证是否通过
if(requestMessage.FunctionCode == Modbus.Modbus.WriteSingleCoil)
{
modiftyData = true;
try
{
_modbusRtuMaster.ValidateWriteSingleCoilResponse(revData, requestMessage);
}
catch(Exception ex)
{
validate = false;
OnDeviceRuningLog(ex.Message);
}
}
else if(requestMessage.FunctionCode==Modbus.Modbus.WriteSingleRegister)
{
modiftyData = true;
try
{
_modbusRtuMaster.ValidateWriteSingleRegisterResponse(revData, requestMessage);
}
catch (Exception ex)
{
validate = false;
OnDeviceRuningLog(ex.Message);
}
} if(modiftyData)
{
if (_devicePacket != null)
{
DeviceFrame df = _devicePacket.DeviceFrames.Where(t => t.TagId == tag.TagId).FirstOrDefault();
if (df != null)
{
if (validate) //正常
{
df.OperationType = "setack";
df.Code = "";
df.Desc = "修改成功";
_modifyConfirm.Add(df.TagId, true);
}
else
{
df.OperationType = "setack";
df.Code = "-1";
df.Desc = "修改失败";
} OnDeviceRuningLog(String.Format("{0},{1}!!!", tag.TagName, df.Desc)); if (_asyncServiceConnectorCallback != null)
{
_asyncServiceConnectorCallback.Invoke(_devicePacket);
}
}
else
{
OnDeviceRuningLog("获得修改设备帧数据为空");
}
bool modifyComplete = true;
foreach(DeviceFrame d in _devicePacket.DeviceFrames)
{
modifyComplete=_modifyConfirm.ContainsKey(d.TagId);
if(!modifyComplete)
{
break;
}
} if(modifyComplete)
{
_devicePacket = null;
_asyncServiceConnectorCallback = null;
_modifyConfirm.Clear();
_sendCommandState = SendCommandState.Complete;
OnDeviceRuningLog("修改参数已全部完成!!!");
}
}
}
5. 应用效果
5.1 CS客户端

5.2 BS浏览器

5.3 Linux环境测试

5.4 视频应用效果
文章:
《.NET Core开发的iNeuOS工业互联网平台,发布 iNeuDA 数据分析展示组件,快捷开发图形报表和数据大屏》
《[视频演示].NET Core开发的iNeuOS物联网平台,实现从设备&PLC、云平台、移动APP数据链路闭环》
《.NET Core开发的iNeuOS物联网平台部署树霉派(raspbian),从网关到云端整体解决方案》
《.NET Core开发的iNeuOS物联网平台部署在Ubuntu操作系统,无缝跨平台》
《iNeuOS 物联网云操作系统2.0发布,集成设备容器、视图建模、机器学习三大模块》
物联网&大数据技术 QQ群:54256083
物联网&大数据合作 QQ群:727664080
联系QQ:504547114
合作微信:wxzz0151
iNeuOS工业互联平台,iNeuKernel(物联网核心组件)远程控制标准化设计与实现。发布v2.3版本。的更多相关文章
- iNeuOS工业互联平台,图表与数据点组合成新组件,进行项目复用
目 录 1. 概述... 1 2. 演示信息... 2 3. 应用过程... 2 1. 概述 针对有些行业的数据已经形成了标准化的建模或者有些公司专注于某 ...
- .NET Core开发的iNeuOS工业互联平台,iNeuKernel物联网核心组件在Docker容器中部署。
目 录 1. 概述... 2 2. 演示信息... 2 3. 安装Docker容器... 2 4. 安装dotnet镜像... 3 5. ...
- iNeuOS工业互联平台,实现动态图元、计算平台、远程控制、数据转发等,和大厂相比如何
目 录 1. 概述... 2 2. 平台演示... 2 3. 增加按钮组态元件... 2 4. 组态图元旋转及动画... 3 5. 后台容 ...
- iNeuOS工业互联平台,.NETCore开发的视频服务组件iNeuVideo,RTSP转WebSocket
目 录 1. 概述... 2 2. 将来集成到iNeuOS平台演示... 3 3. iNeuVideo结构... 3 4. iNeuVideo部署及 ...
- .NET Core开发的iNeuOS工业互联平台,升级四大特性:配置数据接口、图元绑定数据、预警配置和自定义菜单
目 录 1. 概述... 2 2. 演示信息... 2 3. iNeuView(Web组态)配置数据接口... 2 4. iNeuView(Web组 ...
- iNeuOS工业互联平台,开放设备驱动管理、服务驱动管理、云组态自定义画布等,促进平台开放、赋能和落地。发布:v2.3版本。
目 录 1. 概述... 2 2. iNeuOS平台演示... 2 3. 设备驱动管理... 2 4. 服务驱动管理... 3 5. 云组 ...
- iNeuOS工业互联平台,部署在智能硬件网关,实现了从边缘端到云端的一体化部署
目 录 1. 概述... 2 2. 平台演示... 3 3. 智能硬件网关配置(参考)... 3 4. iNeuOS在网关中的部署步骤... 5 4 ...
- iNeuOS工业互联平台,WEB组态(iNeuView)集成rtmp和websocket视频元件,支持海康、大华等摄像头实时显示视频
目 录 1. 概述... 1 2. 平台演示... 2 3. 硬件摄像头... 2 4. 视频流协议转换管理... 2 5. 组态视频元件 ...
- iNeuOS工业互联平台,WEB组态(iNeuView)集成图报组件,满足实时数据图形化展示的需求
目 录 1. 概述... 1 2. 平台演示... 2 3. 应用过程... 3 4. 实时数据展示效果... 5 1. 概述 市场和开源社区有 ...
随机推荐
- jSignature签字板保存为图片
这是本人的第一篇博客,还不会使用.有些简陋,勿怪! 今天要讲的是使用jquery插件jSignature做一个手写板签字的功能,并将签字笔迹保存为图片. 第一步:环境准备 jquery.jSignat ...
- React框架随笔
React框架随笔 现在最热门的前端框架有AngularJS.React.Bootstrap等.自从接触了ReactJS,ReactJs的虚拟DOM(Virtual DOM)和组件化的开发深深的吸引了 ...
- python文件及目录操作
python文件及目录操作 读/写文件 新建/打开文件 写入 #举个例子,打开D:\test\data.txt #以写入模式打开文件 #如果test(上级目录)不存在则报错 #如果data.txt(文 ...
- C#多线程与异步
1.什么是异步同步 如果一个方法被调用,调用者需要等待该方法被执行完毕之后才能继续执行,则是同步. 如果方法被调用后立刻返回,即使该方法是一个耗时操作,也能立刻返回到调用者,调用者不需要等待该方法,则 ...
- Java类成员之构造器
构造器含义: 是指使得JVM在构造对象的时候,帮助进行成员变量的初始化的方法. 构造器(构造方法)格式: 1.对于构造方法而言,方法的名称是固定的,和类名相同. 2.对于构造方法而言,它没有返回值,而 ...
- C++ string 常用函数
C++ String常用函数 一,类型别名 size_type 无符号整型 iterator 迭代器类型 const_iterator 只读迭代器 reverse_iterator 逆序迭代器 con ...
- js的内存泄漏场景、监控以及分析
内存泄漏 Q:什么是内存泄漏? 字面上的意思,申请的内存没有及时回收掉,被泄漏了 Q:为什么会发生内存泄漏? 虽然前端有垃圾回收机制,但当某块无用的内存,却无法被垃圾回收机制认为是垃圾时,也就发生内存 ...
- c++快读与快输模板
快读 inline int read() { ; ; char ch=getchar(); ; ch=getchar();} )+(X<<)+ch-'; ch=getchar();} if ...
- dp - 逆序数序列
对于一个数列{ai},如果有i<j且ai>aj,那么我们称ai与aj为一对逆序对数.若对于任意一个由1~n自然数组成的 数列,可以很容易求出有多少个逆序对数.那么逆序对数为k的这样自然数数 ...
- 计算机基础——常用的Dos命令
d:——切换指定硬盘分区 cd——切换目录,例如:cd D:\下载(使用此命令之前先使用 d: 命令) netstat -ano——查看所有端口号 netstat -a——查看开启了哪些端口 nets ...