11、监测数据采集物联网应用开发步骤(8.2)

这篇具有很好参考价值的文章主要介绍了11、监测数据采集物联网应用开发步骤(8.2)。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

  1. 监测数据采集物联网应用开发步骤(8.1)

新建TCP/IP Client线程类com.zxy.tcp.ClientThread.py

#! python3
# -*- coding: utf-8 -
'''
Created on 2017年05月10日
@author: zxyong 13738196011
'''

import datetime
import socket
import threading
import time

from com.zxy.adminlog.UsAdmin_Log import UsAdmin_Log
from com.zxy.common import Com_Para
from com.zxy.common.Com_Fun import Com_Fun
from com.zxy.tcp.TcpClient import TcpClient
from com.zxy.z_debug import z_debug

#监测数据采集物联网应用--TCP/IP Client线程
class ClientThread(z_debug):
    #断线重连
    idtTimeOut = 60
    sServerIP = "0.0.0.0"
    iPort = 6000
    connectionFlag = False
    
    def __init__(self, timeout, ServerIP, temPort):
        self.idtTimeOut = timeout
        self.sServerIP = ServerIP
        self.iPort = temPort
    
    #inputFlag网络链接是否正常
    def set_dSockList(self,inputFlag):
        key = str(self.sServerIP)+"|"+str(self.iPort) 
        #存在
        if key not in list(Com_Para.dSockList.keys()):
            Com_Para.dSockList[key] = [0,datetime.datetime.now()]
        if inputFlag == False:
            objAry = Com_Para.dSockList[key]
            if objAry[0] <= int(180 / self.idtTimeOut)+12:
                objAry[0] = objAry[0] + 1
            objAry[1] = datetime.datetime.now()
            Com_Para.dSockList[key] = objAry
        else:
            Com_Para.dSockList[key] = [0,datetime.datetime.now()]    
    
    #判断上次链接时间频率是否合规
    def judge_dSock(self):
        key = str(self.sServerIP)+"|"+str(self.iPort) 
        if key not in list(Com_Para.dSockList.keys()):
            Com_Para.dSockList[key] = [0,datetime.datetime.now()]
        objAry = Com_Para.dSockList[key]
        starttime = datetime.datetime.now()
        if objAry[0] <= int(120 / self.idtTimeOut)+1:
            return True
        elif objAry[0] <= int(120 / self.idtTimeOut)+7 and starttime >= objAry[1] + datetime.timedelta(minutes=10):
            return True
        elif objAry[0] <= int(120 / self.idtTimeOut)+12 and starttime >= objAry[1] + datetime.timedelta(hours=1):
            return True
        elif objAry[0] > int(120 / self.idtTimeOut)+12 and starttime >= objAry[1] + datetime.timedelta(hours=1):
            return True
        else:
            return False
        
    def run(self):
        starttime = datetime.datetime.now()       
        endtime = datetime.datetime.now() + datetime.timedelta(seconds=self.idtTimeOut)        
        ckeys = self.sServerIP + "|" + str(self.iPort)
        tc = TcpClient(ckeys)
        t = None        
        try:
            #判断上次链接时间频率是否合规
            if not self.judge_dSock():
                return None
            s = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
            s.connect((self.sServerIP, self.iPort))
            Com_Fun.SetHashTable(Com_Para.dClientThreadList, ckeys, s)            
            self.set_dSockList(True)
            
            temResult = "*"
            Com_Fun.SendSocket(temResult,s)            
            
            t = threading.Thread(target=tc.client_link, name="ClientTh" + ckeys)
            t.start()
        except IOError as e:
            temError = "repeat connect server error:"+self.sServerIP+" "+Com_Fun.GetTime("%Y-%m-%d %H:%M:%S") + repr(e)
            uL = UsAdmin_Log(Com_Para.ApplicationPath, temError)
            uL.WriteLog()
            self.set_dSockList(False);

        while True:
            starttime = datetime.datetime.now()
            try:
                if t is None and starttime <= endtime:
                    if Com_Fun.GetHashTableNone(Com_Para.dClientThreadList, ckeys) is not None:
                        t = threading.Thread(target=tc.client_link, name="ClientTh" + self.sServerIP)
                        t.start()
                    time.sleep(self.idtTimeOut/2)
                elif starttime >= endtime:
                    endtime = datetime.datetime.now() + datetime.timedelta(seconds=self.idtTimeOut)                
                    if Com_Fun.GetHashTableNone(Com_Para.dClientThreadList, ckeys) is None and self.judge_dSock():
                        s = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
                        s.connect((self.sServerIP, self.iPort))          
                        self.set_dSockList(True)
                        Com_Fun.SetHashTable(Com_Para.dClientThreadList, s.getpeername()[0]+"|"+str(s.getpeername()[1]), s)
                        t = threading.Thread(target=tc.client_link, name="ClientTh" + self.sServerIP)
                        t.start()
                    time.sleep(self.idtTimeOut/2)
                #超过10分钟,重新计时
                elif (endtime - starttime).seconds > 10 * self.idtTimeOut:
                    endtime = datetime.datetime.now() + datetime.timedelta(seconds=self.idtTimeOut)
                else:
                    time.sleep(self.idtTimeOut/2)
            except IOError as e:
                temError = "repeat connect server error:"+self.sServerIP+" "+Com_Fun.GetTime("%Y-%m-%d %H:%M:%S") + repr(e)
                uL = UsAdmin_Log(Com_Para.ApplicationPath, temError)
                uL.WriteLog()
                self.set_dSockList(False);
                
    def list_run(self):
        starttime = datetime.datetime.now()       
        endtime = datetime.datetime.now() + datetime.timedelta(seconds=self.idtTimeOut)        
        ckeys = self.sServerIP + "|" + str(self.iPort)
        tc = TcpClient(ckeys)
        t = None        
        try:
            #判断上次链接时间频率是否合规
            if not self.judge_dSock():
                return None
            s = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
            s.connect((self.sServerIP, self.iPort))
            Com_Fun.SetHashTable(Com_Para.dClientThreadList, ckeys, s)      
            self.set_dSockList(True)
            t = threading.Thread(target=tc.client_link, name="ClientTh" + ckeys)
            t.start()
        except IOError as e:
            temError = "repeat connect server error:"+self.sServerIP+" "+Com_Fun.GetTime("%Y-%m-%d %H:%M:%S") + repr(e)
            uL = UsAdmin_Log(Com_Para.ApplicationPath, temError)
            uL.WriteLog()            
            self.set_dSockList(False)
        while True:
            starttime = datetime.datetime.now()
            try:
                if t is None and starttime <= endtime:
                    if Com_Fun.GetHashTableNone(Com_Para.dClientThreadList, ckeys) is not None:
                        t = threading.Thread(target=tc.client_link, name="ClientTh" + self.sServerIP)
                        t.start()
                    time.sleep(self.idtTimeOut/2)
                elif starttime >= endtime:
                    endtime = datetime.datetime.now() + datetime.timedelta(seconds=self.idtTimeOut)                
                    if Com_Fun.GetHashTableNone(Com_Para.dClientThreadList, ckeys) is None and self.judge_dSock():
                        s = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
                        s.connect((self.sServerIP, self.iPort))
                        Com_Fun.SetHashTable(Com_Para.dClientThreadList, s.getpeername()[0]+"|"+str(s.getpeername()[1]), s)   
                        self.set_dSockList(True)
                        t = threading.Thread(target=tc.client_link, name="ClientTh" + self.sServerIP)
                        t.start()
                    time.sleep(self.idtTimeOut/2)
                #超过10分钟,重新计时
                elif (endtime - starttime).seconds > 10 * self.idtTimeOut:
                    endtime = datetime.datetime.now() + datetime.timedelta(seconds=self.idtTimeOut)
                else:
                    time.sleep(self.idtTimeOut/2)
            except IOError as e:
                temError = "repeat connect server error:"+self.sServerIP+" "+Com_Fun.GetTime("%Y-%m-%d %H:%M:%S") + repr(e)
                uL = UsAdmin_Log(Com_Para.ApplicationPath, temError)
                uL.WriteLog()
                self.set_dSockList(False);

新建tcp client数据接收插件类1 com.plugins.Usereflect.testClientReflectClass1.py

#! python3
# -*- coding: utf-8 -
'''
Created on 2017年05月10日
@author: zxyong 13738196011
'''
from com.zxy.z_debug import z_debug

#监测数据采集物联网应用--往平台端发送数据协议拦截器,可组装发送平台数据协议程序
class testClientReflectClass1(z_debug):
    #接收到数据
    strResult        = ""
    #需要发送到服务端数据
    strSend          = ""
    #是否继续执行 1:继续执行 0:中断执行
    strContinue      = "1"        
    #所连接的远端IP
    strIP            = ""
    
    def __init__(self):
        pass

    def init_start(self):
        #作为客户端接收数据拦截器
        if self.strResult == "A01":
            self.strSend = "#send to server data:server1"
        print("AAA作为客户端接收数据拦截器:"+self.strResult)
        self.strResult = "ok"
        #Com_Para.dClientThreadList  本机作为客户端连接socket list
        #Com_Para.htComPort          串口通讯hashtable <String, seria>
#         /*示例:此处写业务逻辑,最后给 strResult重新赋值*/
#         //self.strResult = "test"
#         //self.strSend = "发送到服务端数据"
#         /**************************************************/

新建tcp client数据接收插件类2 com.plugins.Usereflect.testClientReflectClass2.py

#! python3
# -*- coding: utf-8 -
'''
Created on 2017年05月10日
@author: zxyong 13738196011
'''
from com.zxy.z_debug import z_debug

#监测数据采集物联网应用--往平台端发送数据协议拦截器,可组装发送平台数据协议程序
class testClientReflectClass2(z_debug):
    #接收到数据
    strResult        = ""
    #需要发送到服务端数据
    strSend          = ""
    #是否继续执行 1:继续执行 0:中断执行
    strContinue      = "1"        
    #所连接的远端IP
    strIP            = ""
    
    def __init__(self):
        pass

    def init_start(self):
        #作为客户端接收数据拦截器
        if self.strResult == "A02":
            self.strSend = "#send to server data:server"
        print("BBB作为客户端接收数据拦截器:"+self.strResult)
        self.strResult = "ok"
        #Com_Para.dClientThreadList  本机作为客户端连接socket list
        #Com_Para.htComPort          串口通讯hashtable <String, seria>
#         /*示例:此处写业务逻辑,最后给 strResult重新赋值*/
#         //self.strResult = "test"
#         //self.strSend = "发送到服务端数据"
#         /**************************************************/

com.zxy.main.Init_Page.py中添加代码

    @staticmethod
    def Start_Client():       
            try: 
                for temSIP in Com_Para.ServerIPList.split(";"):
                    if temSIP != "":
                        sttem = ClientThread(10, temSIP.split(":")[0], int(temSIP.split(":")[1]))
                        # TCP客户端案例
                        t4tem = threading.Thread(target=sttem.list_run, name="ClientMainThread" + temSIP.split(":")[0])
                        t4tem.start()
            except Exception as e:
                print("TCP client error:" + repr(e)+"=>"+str(e.__traceback__.tb_lineno))
            finally:
                Pass

TCP Client测试案例MonitorDataCmd.py主文件中编写:

在    if __name__ == '__main__':下添加

        #TCP Client配置服务端ip及端口参数
        Com_Para.ServerIPList = "127.0.0.1:5002;127.0.0.1:5003"
        #TCP/IP client连接初始化
        Init_Page.Start_Client()
        
        #暂停3秒钟,tcp client连接需要时间
        time.sleep(3)
        #测试TCP/IP client发送数据
        tcSock = Com_Fun.GetHashTableNone(Com_Para.dClientThreadList,"127.0.0.1|5002")
        #作为客户端接收数据拦截器
        Com_Para.ClientREFLECT_IN_CLASS = "com.plugins.usereflect.testClientReflectClass1"
        if tcSock != None:
            temStr = "TCP client往服务端发送数据:"+Com_Fun.GetTimeDef()+"\r\n"
            print("开始准备发送数据")
            Com_Fun.SendSocket(temStr, tcSock)
            print("TCP client往服务端发送数据")
        else:
            print("TCP Client未准备好")
            
        #改变下作为客户端接收数据拦截器
        #Com_Para.ClientREFLECT_IN_CLASS = "com.plugins.usereflect.testClientReflectClass2"
        #接收数据解析插件已经改变了

运行测试结果如下图:

11、监测数据采集物联网应用开发步骤(8.2),python,物联网

监测数据采集物联网应用开发步骤(9.1)文章来源地址https://www.toymoban.com/news/detail-684327.html

到了这里,关于11、监测数据采集物联网应用开发步骤(8.2)的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 14、监测数据采集物联网应用开发步骤(10)

    监测数据采集物联网应用开发步骤(9.2) Modbus rtu协议开发 本章节在《监测数据采集物联网应用开发步骤(7)》基础上实现可参考《...开发步骤(7)》调试工具,本章节代码需要调用 modbus_tk 组件 , 阅读本章节前建议baidu熟悉modbus rtu协议内容 组件安装 modbus_tk pip3 install modbus_tk 验证

    2024年02月10日
    浏览(53)
  • 7、监测数据采集物联网应用开发步骤(5.3)

    监测数据采集物联网应用开发步骤(5.2) 静态配置库数据库调用,新建全局变量初始化类 com.zxy.main.Init_Page.py 数据库操作测试 MonitorDataCmd.py 主文件中编写: if __name__ == \\\'__main__\\\' : 下编写 程序执行成功结果:自动生成center_data.db 打印出数据库数据 小测试:把上文的sql语句故意语法

    2024年02月10日
    浏览(40)
  • 13、监测数据采集物联网应用开发步骤(9.2)

    监测数据采集物联网应用开发步骤(9.1) TCP/IP Server开发 新建TCP/IP Server线程类 com.zxy.tcp.ServerThread.py 新建作为TCP Server接收数据拦截器插件类 com.plugins.usereflect.testServerReflectInClass1.py 新建作为TCP Server接收数据拦截器插件类 com.plugins.usereflect.testServerReflectInClass2.py 在 com.zxy.main.Init_

    2024年02月10日
    浏览(42)
  • 物联网数据采集网关在工厂数字化转型中的应用

    物联网数据采集网关能将各种传感器、执行器等设备连接在一起,通过收集、处理和传输来自各种物理设备的信息,实现数据的集成和分析,同时可通过云平台进行数据交互。它具有数据转换、数据处理、数据传输等功能,是工厂数字化转型的核心组件。随着科技的飞速发展

    2024年02月22日
    浏览(52)
  • iNeuOS工业互联网操作系统,高效采集数据配置与应用

    1. 概述 2. 通讯原理 3. 参数配置  1.   概述 某生产企业世界500强的集团能源管控平台项目建设,通过专线网络实现异地厂区数据集成, 每个终端能源仪表都有 IP 地址,总共有1000 多台能源表计,总共有将近10000 个数据点 。在集团端部署iNeuOS工业互联网操作系统,终端能源表

    2024年02月05日
    浏览(49)
  • 【雕爷学编程】MicroPython手册之 ESP32-CAM 物联网图像数据采集应用

    MicroPython是为了在嵌入式系统中运行Python 3编程语言而设计的轻量级版本解释器。与常规Python相比,MicroPython解释器体积小(仅100KB左右),通过编译成二进制Executable文件运行,执行效率较高。它使用了轻量级的垃圾回收机制并移除了大部分Python标准库,以适应资源限制的微控制

    2024年02月20日
    浏览(44)
  • 【IoT物联网】IoT小程序在展示中央空调采集数据和实时运行状态上的应用

      利用前端语言实现跨平台应用开发似乎是大势所趋,跨平台并不是一个新的概念,“一次编译、到处运行”是老牌服务端跨平台语言Java的一个基本特性。随着时代的发展,无论是后端开发语言还是前端开发语言,一切都在朝着减少工作量,降低工作成本的方向发展。  

    2024年02月16日
    浏览(39)
  • 水库安全监测方案(实时数据采集、高速数据传输)

    ​ 一、引言 水库的安全监测对于防止水灾和保障人民生命财产安全至关重要。为了提高水库安全监测的效率和准确性,本文将介绍一种使用星创易联DTU200和SG800 5g工业路由器部署的水库安全监测方案。 二、方案概述 本方案主要通过使用星创易联DTU200和SG800 5g工业路由器实现

    2024年02月08日
    浏览(47)
  • 桥梁安全监测系统中数据采集上传用 什么?

    背景 2023年7月6日凌晨时分,G5012恩广高速达万段230公里加80米处6号大桥部分桥面发生垮塌,导致造成2车受损后自燃,3人受轻伤。目前,四川省公安厅交通警察总队高速公路五支队十四大队民警已对现场进行双向管制。 作为世界第一桥梁大国,目前我国公路桥梁数量超过100万

    2024年02月12日
    浏览(41)
  • 工程监测振弦采集仪采集到的数据如何进行分析和处理

    工程监测振弦采集仪采集到的数据如何进行分析和处理 振弦采集仪是一个用于测量和记录物体振动的设备。它通过测量物体表面的振动来提取振动信号数据,然后将其转换为数字信号,以便进行分析和处理。在实际应用中,振弦采集仪是广泛应用于机械、建筑、航空航天和汽

    2024年02月12日
    浏览(49)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包