关于HslCommunication组件的双模式客户端的说明,此说明适用于所有的派生类客户端,包括三菱,西门子,欧姆龙,modbustcp,机器人,simplifyNet客户端等等
前言
本文主要是答疑文章,针对广大网友非常频繁的提问而总结的问题
nuget地址:https://www.nuget.org/packages/HslCommunication/
github地址:https://github.com/dathlin/HslCommunication 如果喜欢可以star或是fork,还可以打赏支持。
联系作者及加群方式(激活码在群里发放):http://www.hslcommunication.cn/Cooperation
在Visual Studio 中的NuGet管理器中可以下载安装,也可以直接在NuGet控制台输入下面的指令安装:
Install-Package HslCommunication
NuGet安装教程 http://www.cnblogs.com/dathlin/p/7705014.html
最简单的使用-短连接
在使用读写数据功能之前,自然是要实例化对象的,然后指定IP地址和端口号的,比如西门子,不需要指定端口好像也能访问,因为内部初始化默认值102了。还有欧姆龙的连接还要指定一些其他的参数信息,所有的客户端访问类只要实例化并指定了相关的参数后,可以理解进行读写数据了,下面随便举几个例子:
三菱的
MelsecMcNet melsec_net = new MelsecMcNet( "192.168.0.188",6000 ); // 然后就可以直接调用了
short value = melsec_net.ReadInt16("D1000").Content;
西门子的
SiemensS7Net siemensTcpNet = new SiemensS7Net( SiemensPLCS.S1200, "192.168.0.100" ); // 然后就是直接调用了
short value = siemensTcpNet.ReadInt16("M100").Content;
欧姆龙的
OmronFinsNet omronFinsNet = new OmronFinsNet( "192.168.0.100",6000 ); // 然后就是直接调用了
short value = omronFinsNet.ReadInt16("D100").Content;
Modbus Tcp的
ModbusTcpNet busTcpClient = new ModbusTcpNet( "192.168.0.100", 502, 0x01); // 然后就可以直接调用了
short value = busTcpClient.ReadInt16("100").Content;
SimplifyNet的,没有指定令牌的情况下
NetSimplifyClient simplifyClient = new NetSimplifyClient( "192.168.0.100",6000 ); // 然后就可以直接调用了
string read = simplifyClient.ReadFromServer( 1, "test")
等等,其他的数据访问派生类都是支持这种模式的。这种是短连接的机制,主要的使用逻辑如下:
也就是说,每次数据请求的时候都要重新连接服务器,然后才开始真正的数据请求,然后再关闭连接。很显然,网络的连接和关闭都是消耗资源的,但是这么做有个好处,没有重新连接的困扰,每次都是新的服务器请求,只要读取失败了,就可以认为是网络已经掉线了,其他的也没有什么可以说的了,接下来看看比较复杂的长连接。
高效数据交互-长连接
为了解决上述的短连接的弊端。当然,如果你对访问频率没有要求,基本就是每秒一次,网络又不是很稳定的情况下,还是挺适合短连接的,如果对读写的速度要求很高,网络又比较好的情况下,无疑是不适合短连接的。怎么使用长连接呢,我们还是举一些例子
三菱的
MelsecMcNet melsec_net = new MelsecMcNet( "192.168.0.188",6000 );
melsec_net.ConnectServer();
// 然后之后调用起来会非常的快
short value = melsec_net.ReadInt16("D1000").Content;
西门子的
SiemensS7Net siemensTcpNet = new SiemensS7Net( SiemensPLCS.S1200, "192.168.0.100" );
siemensTcpNet.ConnectServer();
// 然后之后调用起来会非常的快
short value = siemensTcpNet.ReadInt16("M100").Content;
欧姆龙的
OmronFinsNet omronFinsNet = new OmronFinsNet( "192.168.0.100",6000 );
omronFinsNet.ConnectServer();
// 然后之后调用起来会非常的快
short value = omronFinsNet.ReadInt16("D100").Content;
Modbus Tcp的
ModbusTcpNet busTcpClient = new ModbusTcpNet( "192.168.0.100", 502, 0x01);
busTcpClient.ConnectServer();
// 然后之后调用起来会非常的快
short value = busTcpClient.ReadInt16("100").Content;
SimplifyNet的,没有指定令牌的情况下
NetSimplifyClient simplifyClient = new NetSimplifyClient( "192.168.0.100",6000 );
simplifyClient.ConnectServer();
// 然后之后调用起来会非常的快
string read = simplifyClient.ReadFromServer( 1, "test")
等等,如果想要知道是否连接成功的话就参照下面的代码
OperateResult connect = client.ConnectServer();
if(connect.IsSuccess)
{
MessageBox.Show("连接成功");
}
else
{
MessageBox.Show("连接失败");
}
然后讲讲这个程序的背后的思路,比短连接复杂一些
对调用者来说,其实都是循环的调用就可以了,正常情况下和短连接的调用方法都是一致的,问题就是出现在了我本来好好的数据请求中,突然网络不行了,然后我下一次读取失败了,这时候,不用着急,继续循环读取就可以了,内部有逻辑,如果上次读取的时候发生了网络故障,通常因为断线,对方强制关闭,导致的。那么在下次读取的时候,会自动先去连接服务器,如果成功了,那么这次的数据交互自然也就成功了,如果连接失败了,那么在下下次读取的时候又会重连,直到成功为止。
延迟启动长连接
上面的长连接的模式,还有个小小的瑕疵,我在切换长连接时必须要连接服务器,但是我的软件可能并不是立马进行读取的,可能过很久之后才开始读取数据,所以本组件也支持手动设置长连接,直到第一次读取数据的时候才开始连接服务器,后面的操作就是和上面的一致了。整个逻辑就是这个样子的
原理就是调用一个方法,设置为长连接模式,等待真正进行数据交互的时候,才真的连接到服务器进行读取。
异形模式
由于PLC永远不会主动连接的能力,所以异形模式只适用于Modbus客户端,因为Modbus里有支持主动连接的服务器,具体参照
http://www.cnblogs.com/dathlin/p/8934266.html
关于HslCommunication组件的双模式客户端的说明,此说明适用于所有的派生类客户端,包括三菱,西门子,欧姆龙,modbustcp,机器人,simplifyNet客户端等等的更多相关文章
- HslCommunication组件库使用说明 (转载)
一个由个人开发的组件库,携带了一些众多的功能,包含了数据网络通信,文件上传下载,日志组件,PLC访问类,还有一些其他的基础类库. nuget地址:https://www.nuget.org/packa ...
- HslCommunication组件库使用说明
一个由个人开发的组件库,携带了一些众多的功能,包含了数据网络通信,文件上传下载,日志组件,PLC访问类,还有一些其他的基础类库. nuget地址:https://www.nuget.org/packa ...
- 如何理解Unity组件化开发模式
Unity的开发模式核心:节点和组件,组件可以加载到任何节点上,每个组件都有 gameobject 属性,可以通过这个属性获取到该节点,即游戏物体. 也就是说游戏物体由节点和组件构成,每个组件表示物体 ...
- 派生类&简单工厂模式
派生类&简单工厂模式 git链接: Operation3.1.1 题目描述的代码部分的解释 首先是声明一个Rand类作为父类,然后两个子类RandNumber类和RandOperation类, ...
- 3.3 建立松耦合组件(MVC 模式最重要的特性之一是它支持、关注“分离”)《精通 ASP.NET MVC 5》 推荐指数:8 星半
笔者通常希望应用程序中的组件尽可能独立,而只有很少几个可控的依赖项.—— 在理想情况下,每个组件都不了解其他组件,而只是通过抽象接口来处理应用程序的其他区域.这称为松耦合 .—— 它能够使应用程序更易 ...
- Unityclient框架笔记二(组件实体开发模式的思考)
Unity的Entity-Component-System实现的很美丽,很灵活.许多文章也对这样的组件实体的开发模式倍加推崇.由于它契合这么一条规则:优先使用组合而不是继承. 可是实际开发过程中,限制 ...
- vue-music 关于Player (播放器组件)--播放模式
播放器播放模式有三种,顺序播放,单曲循环,随机播放,定义在vuex 中的字段为 mode.点击切换播放模式的图标.切换模式判断是否为随机播放,如果是随机播放模式,则取得sequenceList 列表数 ...
- Android图片管理组件(双缓存+异步加载)
转自:http://www.oschina.net/code/snippet_219356_18887?p=3#comments ImageManager2这个类具有异步从网络下载图片,从sd读取本地 ...
- android自定义日期组件之双DatePicker
1.效果图(两个DatePicker放在一起,同时选择起始与结束时间): 2.实现 2.1布局文件: <?xml version="1.0" encoding="u ...
随机推荐
- linux下安装mysql详细步骤
最近买了个阿里云服务器,搭建mysql环境. 该笔记用于系统上未装过mysql的干净系统第一次安装mysql.自己指定安装目录,指定数据文件目录. linux系统版本: CentOS 7.3 64位 ...
- 分布式系列 - dubbo服务发布
单元测试OK,封装为Dubbo服务. 添加依赖 pom.xml <properties> <dubbo.version>2.5.3</dubbo.ve ...
- Tensorflow平台快速搭建:Windows 7+TensorFlow 0.12.0
Tensorflow平台快速搭建:Windows 7+TensorFlow 0.12.0 1.TensorFlow 0.12.0下载 2016年11月29日,距离TensorFlow 宣布开源刚刚过去 ...
- 将应用注册为Linux的服务
主流的Linux大多使用init.d或systemd来注册服务.下面以centos6.6演示init.d注册服务:以centos7.1演示systemd注册服务. 1. 基于Linux的init.d部 ...
- 第七篇:Spark SQL 源码分析之Physical Plan 到 RDD的具体实现
/** Spark SQL源码分析系列文章*/ 接上一篇文章Spark SQL Catalyst源码分析之Physical Plan,本文将介绍Physical Plan的toRDD的具体实现细节: ...
- [小问题笔记(七)] JS和 jQuery常用语句笔记(隐藏/显示/禁用标签 日期操作 跳转等)
隐藏/显示标签 $("#div1").css("display", "none");$("#div2").css(&qu ...
- UVa 11149 矩阵的幂(矩阵倍增法模板题)
https://vjudge.net/problem/UVA-11149 题意: 输入一个n×n矩阵A,计算A+A^2+A^3+...A^k的值. 思路: 矩阵倍增法. 处理方法如下,一直化简下去直到 ...
- 实现基本的Ajax和Json请求
前面已经封装好了一个方法ajax(),通过这个方法可以实现Ajax请求,接下来就是给出 例程来测试这个方法和实现简单的功能. 视图的部分代码如下: <body> <div> ...
- logback MDC 使用
有时候想在logback日志中打印请求IP.流水号这些信息,可以通过MDC(Mapped Diagnostic Contexts)实现: MDC.put("requestNo", ...
- Oracle数据库报错: ORA-29275:部分多字节字符
Oracle数据库报错: ORA-29275:部分多字节字符 就是你查出来的字符串(有汉字的)有可能会出问题, 在认为有问题的字段 用 to_nchar("字段")包起来 比如 你 ...