<meter id="pryje"><nav id="pryje"><delect id="pryje"></delect></nav></meter>
          <label id="pryje"></label>

          新聞中心

          EEPW首頁 > 嵌入式系統(tǒng) > 設計應用 > 如何在Dragonbaord 410c上實現(xiàn)高性能并發(fā)處理TCP服務器

          如何在Dragonbaord 410c上實現(xiàn)高性能并發(fā)處理TCP服務器

          作者: 時間:2017-10-11 來源:網(wǎng)絡 收藏

          在IOT設計中,通常我們需要構建一個或者多個監(jiān)測和控制網(wǎng)絡,來實現(xiàn)對各種傳感器及設備的數(shù)據(jù)采集和控制,這樣我們就需要在網(wǎng)絡中實現(xiàn)集中管理終端,以對區(qū)域的傳感器和設備進行集中管理,在云端和底層控制節(jié)點之間維護一個智能化的管理終端,dragonboard 410c憑借其強大的處理性能和網(wǎng)絡連接能力,可以方便的實現(xiàn)這一管理終端功能,此時我們就需要在dragonbaord 410c上設計一個多任務的接入服務,讓傳感器和相關的控制設備接入,為此,本期blog將向大家介紹如何使用gevent高性能的并發(fā)處理庫在draognbaord 410c上來實現(xiàn)一個高性能的TCP服務器。

          本文引用地址:http://www.ex-cimer.com/article/201710/365545.htm

          gevent是基于協(xié)程的Python網(wǎng)絡庫。特點: 基于libev的快速事件循環(huán)(Linux上epoll,F(xiàn)reeBSD上kqueue)。 基于greenlet的輕量級執(zhí)行單元。 API的概念和Python標準庫一致(如事件,隊列)。 可以配合socket,ssl模塊使用。 能夠使用標準庫和第三方模塊創(chuàng)建標準的阻塞套接字(gevent.monkey)。

          使用gevent來提高我們的并發(fā)處理性能,首先需要在draongboard 410c上安裝gevent模塊,具體安裝方法如下:

          sudo apt-get install libevent-dev

          sudo apt-get install python-all-dev

          sudo apt-get install python-setuptools

          sudo easy_install greenlet

          sudo easy_install gevent

          完成安裝后,from gevent.server import StreamServer 就可以導入使用gevent來實現(xiàn)高效的并發(fā)處理,這里我們以構建一個簡答的業(yè)務邏輯處理服務為例,具體代碼如下:

          from gevent.server import StreamServer

          import addressbook_pb2

          from testBusinessLogic import testBusinessLogic

          BUFSIZE=1024

          reportLenMin=10

          def handle(socket,address):

          while(1):

          try:

          report=socket.recv(BUFSIZE)

          print(report)

          if len(report)>reportLenMin:

          testLogic=testBusinessLogic(report,“192.168.1.156”)

          testLogic.startMainLogicProcess(socket)

          else:

          print(“recv report error”)

          socket.send(“your report is error”)

          except:

          print(“service error”)

          socket.send(“service error”)

          if __name__==“__main__”:

          testServer = StreamServer((‘192.168.41.156’,5000),handle)

          testServer.serve_forever()

          到這里我們就完成了整個測試服務器的搭建,該服務器能夠借助于gevent實現(xiàn)高并發(fā)的處理,并且支持異常處理,可以在dragonbaord 410c上穩(wěn)定運行,這里testBusinessLogic為測試邏輯處理類,大家需要實現(xiàn)的業(yè)務邏輯可以放到里面實現(xiàn),具體不詳細介紹。



          關鍵詞: DragonBoard410c

          評論


          相關推薦

          技術專區(qū)

          關閉
          看屁屁www成人影院,亚洲人妻成人图片,亚洲精品成人午夜在线,日韩在线 欧美成人 (function(){ var bp = document.createElement('script'); var curProtocol = window.location.protocol.split(':')[0]; if (curProtocol === 'https') { bp.src = 'https://zz.bdstatic.com/linksubmit/push.js'; } else { bp.src = 'http://push.zhanzhang.baidu.com/push.js'; } var s = document.getElementsByTagName("script")[0]; s.parentNode.insertBefore(bp, s); })();