基于surging的木舟IOT平台如何添加网络组件
一 、 概述
为了弥补代码的遗失,木舟IOT平台正在加班加点进行研发,后面不只是针对于IOT设备接入上报,告警,视频管理,组态数据可视化大屏,后面还会有快速搭建微服务平台,利用surging.cli工具根据数据库表生成微服务,中间服务,能让程序员快速完成BOSS交给的任务,从而在这个内卷的社会能占有一席之地。这些都是没有完成任务的空话,现在发此篇的目的是作者有能力开发出优秀的IOT平台,先介绍一个比较突出的功能,就是可以基于共享或者独立配置添加网络组件, 下面来介绍一下如何添加网络组件。
一键运行打包成品下载:https://pan.baidu.com/s/11hcf9ieCkJxlGrzvIuxeQA?pwd=ajsr
测试用户:fanly
测试密码:123456
为了让大家节约时间,能尽快运行产品看到效果,上面有 一键运行打包成品可以进行下载测试运行。
二、如何测试运行
以下是目录结构,
IDE:consul 注册中心
kayak.client: 网关
kayak.server:微服务
apache-skywalking-apm:skywalking链路跟踪

以上是目录结构,大家不需要一个个运行,只需要打开运行startup.bat,如果需要测试skywalking ,只需要apache-skywalking-apm\bin\startup.bat 文件就可以了,以下是运行的界面
三、如何添加组件
1.添加http服务组件,
打开平台界面,然后点击设备接入->网络组件,然后可以看到如下界面

再点击新增组件或者编辑组件,完成后注意启动状态是关闭状态,此时并不能对于该组件功能进行访问调用,只有把启动状态打开,才能访问调用

以上是http服务组件,启动完成后,如何设置了webservice和swagger,你可以访问webservice和swagger是否可以访问


2.添加/编辑Tcp服务组件
当添加/编辑Tcp组件时,设置Host:127.0.0.1 ,port:248并且还有解析方式选项,选项里面有不处理,固定长度,分隔符,自定义脚本,下面我们就来看自定义脚本

添加脚本如下:
parser.Fixed(4).Handler(
function(buffer){
var buf = BytesUtils.Slice(buffer,1,4);
parser.Fixed(buffer.ReadableBytes).Result(buf);
}).Handler(
function(buffer){parser.Fixed(8).Result(buffer);}
).Handler(function(buffer){
parser.Result('处理完成','gb2312').Complete();
}
)
而基于TCP服务代码如下,需要继承于TcpBehavior
internal class TcpDeviceDataService : TcpBehavior, ITcpDeviceDataService
{
private readonly IDeviceProvider _deviceProvider;
public TcpDeviceDataService(IDeviceProvider deviceProvider)
{
_deviceProvider = deviceProvider;
} public override void Load(string clientId, NetworkProperties tcpServerProperties)
{
var deviceStatus = _deviceProvider.IsConnected(clientId);
this.Parser.HandlePayload().Subscribe(async buffer => await ParserBuffer(buffer));
} public override void DeviceStatusProcess(DeviceStatus status, string clientId, NetworkProperties tcpServerProperties)
{
//throw new NotImplementedException();
} public async Task ParserBuffer(IByteBuffer buffer)
{
List<string> result = new List<string>();
while (buffer.ReadableBytes > 0)
{
result.Add(buffer.ReadString(this.Parser.GetNextFixedRecordLength(),
Encoding.GetEncoding("gb2312")));
} // var str= buffer.ReadString(buffer.ReadableBytes, Encoding.UTF8); var byteBuffer = Unpooled.Buffer();
byteBuffer.WriteString("\r\n", Encoding.UTF8);
byteBuffer.WriteString("处理完成", Encoding.GetEncoding("gb2312"));
await Sender.SendAndFlushAsync(byteBuffer);
// await Sender.SendAndFlushAsync("消息已接收",Encoding.GetEncoding("gb2312"));
this.Parser.Close();
} public Task<bool> ChangeDeviceStage(string deviceId)
{
throw new NotImplementedException();
}
}
用测试Tcp调试工具结果如下

3.添加/编辑UDP服务组件
当添加/编辑UDP组件时, 设置Host:127.0.0.1 ,port:267 并且可以是否开启组播

而基于udp服务代码如下,需要继承于UdpBehavior
internal class UdpDeviceDataService : UdpBehavior, IUdpDeviceDataService
{
public Task<bool> ChangeDeviceStage(string deviceId)
{
throw new NotImplementedException();
} public override async Task Dispatch(IEnumerable<byte> bytes)
{
await Sender.SendAndFlushAsync("\r\n", Encoding.UTF8);
await Sender.SendAndFlushAsync("处理完成", Encoding.GetEncoding("gb2312"));
}
}
测试结果如下:

4.添加/编辑WebSocket服务组件
当添加/编辑WebSocket组件时, 设置Host:127.0.0.1 ,port:55

而基于websocket服务代码如下,需要继承于WSBehavior
internal class WSDeviceDataService : WSBehavior, IWSDeviceDataService
{
protected override void OnMessage(MessageEventArgs e)
{
this.Client.Value.SendTo($"send:{e.Data},\r\n reply:hello,welcome to you!",ID);
} protected override void OnOpen()
{ }
}
测试结果如下:

5.添加/编辑UDP服务组件
当添加/编辑WebSocket组件时, 设置Host:127.0.0.1 ,port:345

添加greet.proto文件,脚本如下:
syntax = "proto3";
package Greet;
service Greeter {
// Sends a greeting
rpc ChangeDeviceStage (DeviceRequest) returns (DeviceReply) {}
}
message DeviceRequest {
string deviceId = 1;
}
message DeviceReply {
bool message = 1;
}
然后再创建GreeterBehavior,继承Greeter.GreeterBase, IServiceBehavior,代码如下
public partial class GreeterBehavior : Greeter.GreeterBase, IServiceBehavior
{
private ServerReceivedDelegate received;
public event ServerReceivedDelegate Received
{
add
{
if (value == null)
{
received += value;
}
}
remove
{
received -= value;
}
} public string MessageId { get; } = Guid.NewGuid().ToString("N");
public async Task Write(object result, int statusCode = 200, string exceptionMessage = "")
{
if (received == null)
return;
var message = new TransportMessage(MessageId, new ReactiveResultMessage
{
ExceptionMessage = exceptionMessage,
StatusCode = statusCode,
Result = result });
await received(message);
} public T CreateProxy<T>(string key) where T : class
{
return ServiceLocator.GetService<IServiceProxyFactory>().CreateProxy<T>(key);
} public object CreateProxy(Type type)
{
return ServiceLocator.GetService<IServiceProxyFactory>().CreateProxy(type);
} public object CreateProxy(string key, Type type)
{
return ServiceLocator.GetService<IServiceProxyFactory>().CreateProxy(key, type);
} public T CreateProxy<T>() where T : class
{
return ServiceLocator.GetService<IServiceProxyFactory>().CreateProxy<T>();
} public T GetService<T>(string key) where T : class
{
if (ServiceLocator.Current.IsRegisteredWithKey<T>(key))
return ServiceLocator.GetService<T>(key);
else
return ServiceLocator.GetService<IServiceProxyFactory>().CreateProxy<T>(key);
} public T GetService<T>() where T : class
{
if (ServiceLocator.Current.IsRegistered<T>())
return ServiceLocator.GetService<T>();
else
return ServiceLocator.GetService<IServiceProxyFactory>().CreateProxy<T>(); } public object GetService(Type type)
{
if (ServiceLocator.Current.IsRegistered(type))
return ServiceLocator.GetService(type);
else
return ServiceLocator.GetService<IServiceProxyFactory>().CreateProxy(type);
} public object GetService(string key, Type type)
{
if (ServiceLocator.Current.IsRegisteredWithKey(key, type))
return ServiceLocator.GetService(key, type);
else
return ServiceLocator.GetService<IServiceProxyFactory>().CreateProxy(key, type); }
public void Publish(IntegrationEvent @event)
{
GetService<IEventBus>().Publish(@event);
} }
而基于grpc服务代码如下,需要继承于刚刚创建的GreeterBehavior
public class GrpcDeviceDataService : GreeterBehavior, IGrpcDeviceDataService
{
public override Task<DeviceReply> ChangeDeviceStage(DeviceRequest request, ServerCallContext context)
{
return Task.FromResult(new DeviceReply
{
Message = true
}) ;
}
}
以下是测试结果:
6.添加/编辑MQTT服务组件
当添加/编辑WebSocket组件时, 设置Host:127.0.0.1 ,port:425

而基于mqtt服务代码如下,需要继承于MqttBehavior
public class MQTTDeviceDataService : MqttBehavior, IMQTTDeviceDataService
{
public override async Task<bool> Authorized(string username, string password)
{
bool result = false;
if (username == "admin" && password == "123456")
result = true;
return await Task.FromResult(result);
} public async Task<bool> IsOnline(string deviceId)
{
return await base.GetDeviceIsOnine(deviceId);
} public async Task Publish(string deviceId, WillMessage message)
{
var willMessage = new MqttWillMessage
{
WillMessage = message.Message,
Qos = message.Qos,
Topic = message.Topic,
WillRetain = message.WillRetain
};
await Publish(deviceId, willMessage);
await RemotePublish(deviceId, willMessage);
}
}
以下是测试结果:

三、总结
木舟IOT平台会在github开源社区版本,可以自由更改代码,用于商业项目,但不能自营平台,如低代码平台,IOT平台等,如有违反,后果自负,还有最好不要更改命名空间,然后跟公司说是自己研发的,如果知道后,我在博客全网通报此人,以前surging相关的事件就算了,就当没发生过。,如果碰到困难,比较紧急的话,可以联系作者,加群:744677125
基于surging的木舟IOT平台如何添加网络组件的更多相关文章
- 低代码平台--基于surging开发微服务编排流程引擎构思
前言 微服务对于各位并不陌生,在互联网浪潮下不是在学习微服务的路上,就是在使用改造的路上,每个人对于微服务都有自己理解,有用k8s 就说自己是微服务,有用一些第三方框架spring cloud, du ...
- 基于surging网络组件多协议适配的平台化发展
前言 Surging 发展已经有快6年的时间,经过这些年的发展,功能框架也趋于成熟,但是针对于商业化需求还需要不断的打磨,前段时间客户找到我想升级成平台化,针对他的需求我 ...
- Polaristech 刘洋:基于 OpenResty/Kong 构建边缘计算平台
2019 年 3 月 23 日,OpenResty 社区联合又拍云,举办 OpenResty × Open Talk 全国巡回沙龙·北京站,Polaristech 技术专家刘洋在活动上做了<基于 ...
- 聊聊如何在华为云IoT平台进行产品开发
摘要:华为云物联网平台承载着南北向数据互通的功能职责. 本文分享自华为云社区<如何基于华为云IoT物联网平台进行产品开发>,作者: Super.雯 . 华为云物联网平台承载着南北向数据互通 ...
- 搭建基于python +opencv+Beautifulsoup+Neurolab机器学习平台
搭建基于python +opencv+Beautifulsoup+Neurolab机器学习平台 By 子敬叔叔 最近在学习麦好的<机器学习实践指南案例应用解析第二版>,在安装学习环境的时候 ...
- Android中实现java与PHP服务器(基于新浪云免费云平台)http通信详解
Android中实现java与PHP服务器(基于新浪云免费云平台)http通信详解 (本文转自: http://blog.csdn.net/yinhaide/article/details/44756 ...
- 基于AgileEAS.NET企业应用开发平台的分布式解决方案
开篇 分布式应用 AgileEAS.NET基于Microsoft .Net构件技术而构建,Microsoft .Net最吸引人的莫过于分布式应用技术,基已经提供了XML WebService. .Ne ...
- 基于Activiti的流程应用开发平台JSAAS-WF V5.3
第1章 产品概述及体系架构 1.1.概述 红迅JSAAS-WF工作流平台V5是广州红迅软件有限公司面向合作伙伴以及有IT运维团队中大型企业提供新一代的流程管理产品,它基于流行的JAVA开源技术上构建, ...
- 【毕业设计】基于Android的家校互动平台开发(内含完整代码和所有文档)——爱吖校推(你关注的,我们才推)
☆ 写在前面 之前答应大家的毕业答辩之后把所有文档贡献出来,现在答辩已过,LZ信守承诺,把所有文档开源到了GitHub(这个地址包含所有的代码和文档以及PPT,外层为简单的代码).还望喜欢的朋友们,不 ...
- windows平台下基于QT和OpenCV搭建图像处理平台
在之前的博客中,已经分别比较详细地阐述了"windows平台下基于VS和OpenCV"以及"Linux平台下基于QT和OpenCV"搭建图像处理框架,并 ...
随机推荐
- SpringBoot 整合模板引擎 jetbrick-template
添加依赖 <dependency> <groupId>com.github.subchen</groupId> <artifactId>jetbrick ...
- 基于Redis在定时任务里判断其他定时任务是否已经正常执行完的方案
执行的定时任务是基于其他定时任务计算得到的结果基础上做操作的,那么如何来确定其他存在数据依赖的定时任务已经执行完成呢? 在分布式环境里,可通过集群的redis来解决这个问题: 即,在跑批任务开始时,将 ...
- Python生成PDF:Reportlab的六种使用方式
Reportlab是Python创建PDF文档的功能库 这里是整理过的六种Reportlab使用方式,主要参考的是<ReportLab User Guide> 一.使用文档模板DocTem ...
- linux 查看crontab任务执行情况
首先创建一个定时任务,例如: */1 * * * * /usr/bin/curl http://******/admin/Keeperclock/keeper >> /data/wwwro ...
- PHP中substr() mb_substr() mb_struct()的区别和用法
PHP substr() 函数可以分割文字,但要分割的文字如果包括中文字符往往会遇到问题,这时可以用mb_substr()/mb_strcut这个函 数,mb_substr() /mb_strcut的 ...
- 第五节 JMeter基础-初级登录【断言的好处】
声明:本文所记录的仅本次操作学习到的知识点,其中商城IP错误,请自行更改. 1.认识JMeter (1)断言 预期结果和实际结果的比较,如果不一样,断言失败. 2.注册 (1)直接复制[登录]粘贴一下 ...
- 5、Git之版本号
5.1.概述 每一次提交,Git 都会生成相关的版本号:每个版本号由 40 位 16 进制的数字组成. 这 40 位 16 进制的数字,是根据提交的内容,通过 SHA-1 算法计算出来的. 版本号具体 ...
- 【Java】Properties 配置信息类
Properties 配置信息类 Properties 是HashTable的子类,该对象用于处理属性文件 由于属性文件的Key.Value都是字符串类型,所以Properties里的Key和Valu ...
- 【RabbitMQ】08 深入部分P1 可靠性投递
1.消息投递确认 这里的代码延用了06的东西: https://www.cnblogs.com/mindzone/p/15374684.html 删除之前的整合案例,重新写了一份案例的队列和交换机配置 ...
- 【Hibernate】03 配置文件 & API
映射器文件: - 字段的Column属性可以不写缺省,这将表示和实体类的属性标识一样 - type 属性用于声明表字段在Java中的类型,这个属性可不写缺省,自动匹配 Hibernate 4个核心AP ...
