In addition to Weibo, there is also WeChat
Please pay attention
WeChat public account
Shulou
2025-01-19 Update From: SLTechnology News&Howtos shulou NAV: SLTechnology News&Howtos > Development >
Share
Shulou(Shulou.com)06/03 Report--
This article mainly shows you the "serversuperio sharing terminal control sensor or device formation loop control example analysis", the content is easy to understand, clear, hope to help you solve your doubts, the following let the editor lead you to study and learn "serversuperio sharing terminal control sensor or device formation loop control example analysis" this article.
21.1 Overview
The previous work done by ServerSuperIO gradually lays the foundation for the formation of loop control or cascade control, such as the development and application of service connectors and device-driven connectors. In short, it is through a variety of forms to issue commands to control the device (drive) or sensor, cloud control station or monitoring point sensor, App or other terminal control sensor, according to the sensor data collected by the sensor to control another sensor and so on.
Here's how the cloud, App, or other terminals control sensor devices (similar to sensor control sensors, see: 12. The development of service interfaces and two-way interaction with the cloud. According to the communication protocol, the structured scheme does not need too much code to complete the corresponding function. The effect is as follows:
21.2 structural schematic diagram
The control side initiates the control command, develops a simple proxy service with the ServerSuperIO service interface, and interacts with the device driver through the service connector IServiceConnector interface. After receiving the control command, the device driver sends it to the device or sensor, waits for the confirmation message returned by the control, and then returns to the control side.
21.3 communication protocol
Some people ask why not use the MQTT protocol, and how can it be compatible with the protocols of different devices and sensors? In view of the actual situation in China, it is obvious that it can not reach the level of a unified standard, and in a bad economy, it is impossible for enterprises to invest in replacing the original hardware equipment. It is also not in line with the principle of ServerSuperIO design, that is, protocol independence, and any standard or non-standard protocol can be integrated. If you want to cross a river, repair the bridge, set up the ropeway, set up the boat. It's up to you to decide how to cross the river.
Someone asked what protocols have been integrated into ServerSuperIO? The answer has been given above, and what I want to say is that there is no framework that can cure all diseases. From the opposite point of view, if any protocol is added like configuration, how much value the enterprise wants to give for peer-to-peer exchange, so the protocol driver should be written by everyone.
The protocol we demonstrate is shown in the following figure:
21.4 control terminal
There are many kinds of control side: sending control commands to subordinates in the cloud, sending control commands to App or PC software connection service, and so on. Send control commands as shown below:
21.5 proxy service (SSIO service interface)
The proxy service is implemented through ServerSuperIO's IService interface. In the inheritance class, the proxy service is developed using the singleton pattern of the ServerSuperIO framework itself. The code is as follows:
Public override void StartService () {string devId = "ControlDeviceService"; Driver dev = new Driver (); dev.ReceiveRequestInfos + = Dev_ReceiveRequestInfos; dev.DeviceParameter.DeviceName = "Control device driver"; dev.DeviceParameter.DeviceAddr = 0; dev.DeviceParameter.DeviceID = devId; dev.DeviceParameter.DeviceCode = ""; dev.DeviceDynamic.DeviceID = devId Dev.DeviceParameter.NET.RemoteIP = "127.0.0.1"; dev.DeviceParameter.NET.RemotePort = 9600; dev.DeviceParameter.NET.ControllerGroup = "LocalGroup"; dev.CommunicateType = CommunicateType.NET; dev.Initialize (devId) IServer server = new ServerManager (). CreateServer (new ServerConfig () {ServerName = "Control equipment Service", ListenPort=6670, ComReadTimeout = 1000, ComWriteTimeout = 1000, NetReceiveTimeout = 1000, NetSendTimeout = 1000, ControlMode = ControlMode.Singleton, SocketMode = SocketMode.Tcp StartReceiveDataFliter = false, ClearSocketSession = false, StartCheckPackageLength = false, CheckSameSocketSession = false,}) Server.AddDeviceCompleted + = server_AddDeviceCompleted; server.DeleteDeviceCompleted + = server_DeleteDeviceCompleted; server.SocketConnected + = server_SocketConnected; server.SocketClosed + = server_SocketClosed; server.Start (); server.AddDevice (dev);}
The dev.ReceiveRequestInfos event is the event interface that the control driver inherits the extension of the RunDevice driver class in the ServerSuperIO framework. The ServerSuperIO singleton pattern receives the data information, and if it conforms to the protocol standard, it will feedback the data information to the driver's Communicate interface, and the ReceiveRequestInfos event will transmit the data information to the Dev_ReceiveRequestInfos function of the proxy service subscribing to the event. The code is shown below:
The Dev_ReceiveRequestInfos function in the proxy service passes the information to the corresponding device driver according to DeviceCode (addr) through the service connector interface IServiceConnector. The code is shown below:
The proxy service receives the result information feedback from the device driver through the ServiceConnectorCallback and ServiceConnectorCallbackError function interfaces. If there is an exception in the middle, ServiceConnectorCallbackError will be called, and if the ServiceConnectorCallback function is called normally, the ServiceConnectorCallback function interface will send the result to the controller according to the corresponding relationship between the recorded command and the IO channel. The ServiceConnectorCallback code is shown below:
There is a note in this, that is, the device driver does not feedback the confirmation of the control command within a specified period of time, that is, the sensor does not feedback the corresponding information. In this case, a timing detection service is added. If there is no feedback on the timeout, the corresponding message is sent to the controller. The code is shown below:
21.6 device driver
The device driver corresponds to the sensor and interacts with each other. The device-driven RunServiceConnector interface is responsible for receiving the command information passed by the proxy service Dev_ReceiveRequestInfos (OnServiceConnector) function. The code is shown below:
There are two points: 1. After receiving the command data, you can immediately send the data information through the OnSendData function to find the corresponding IO channel with the set IP, which is suitable for the automatic control mode. two。 After receiving the command data, put it in the this.Protocol.SendCache protocol cache and wait for the command to be issued, which is suitable for polling and concurrent mode.
For the isAsyn parameter of the returned result object ServiceConnectorCallbackResult, if it is true, the result information is returned through AsyncServiceConnectorCallback callback, that is, you have to wait for the sensor to return the confirmation information, and the device driver receives it and then feedback it to the proxy service; if it is false, the description will immediately feedback to the proxy service, which is suitable for transmitting data information regardless of whether the interaction with the sensor is successful or not.
You can temporarily save the callback parameter in this function, wait for the sensor to return a confirmation message, and then trigger an asynchronous callback to the proxy service in the Communicate function. The code is shown below:
The above is all the contents of the article "sample Analysis of serversuperio sharing Terminal Control Sensor or device forming Loop Control". Thank you for reading! I believe we all have a certain understanding, hope to share the content to help you, if you want to learn more knowledge, welcome to follow the industry information channel!
Welcome to subscribe "Shulou Technology Information " to get latest news, interesting things and hot topics in the IT industry, and controls the hottest and latest Internet news, technology news and IT industry trends.
Views: 0
*The comments in the above article only represent the author's personal views and do not represent the views and positions of this website. If you have more insights, please feel free to contribute and share.
Continue with the installation of the previous hadoop.First, install zookooper1. Decompress zookoope
"Every 5-10 years, there's a rare product, a really special, very unusual product that's the most un
© 2024 shulou.com SLNews company. All rights reserved.