欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Python TCPServer 多線程多客戶端通信的實(shí)現(xiàn)

 更新時(shí)間:2019年12月31日 14:28:01   作者:東南飄雪  
這篇文章主要介紹了Python TCPServer 多線程多客戶端通信的實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧

最簡(jiǎn)單、原始的TCP通信demo

服務(wù)端Http請(qǐng)求:

import socket

# 創(chuàng)建一個(gè)servicesocke
serviceSocket = socket.socket(socket.AF_INET, socket.SOCK_STREAM)

# 給服務(wù)器綁定地址(ip地址,端口號(hào))
serviceSocket.bind(("192.168.171.1", 80))

print("等待客戶端接入")
# sock 是客戶端的socket信息
# addr 是客戶端的地址(ip,端口)
sock, addr = serviceSocket.accept()
print(f"sock from client:{sock}")
print(f"addr of client:{addr}")

while True:
  # 接收客戶端的請(qǐng)求
  recvData = sock.recv(1024)
  print("客戶端說(shuō):%s" % (recvData.decode("utf-8")))
  sendData = input("服務(wù)器說(shuō):")
  # 發(fā)送(回復(fù))數(shù)據(jù)給客戶端
  sock.send(sendData.encode("utf-8"))

客戶端Http請(qǐng)求:

import socket

# 創(chuàng)建客戶端socket
clientSocket = socket.socket(socket.AF_INET, socket.SOCK_STREAM)

# 連接服務(wù)器
clientSocket.connect(("192.168.171.1", 80))

while True:
  # 發(fā)送消息給服務(wù)器
  sendData = input("客戶端說(shuō):")
  if sendData == "bye":
    clientSocket.send(sendData.encode("utf-8")) # 編碼:將數(shù)據(jù)裝換成二進(jìn)制形式
    break
  clientSocket.send(sendData.encode("utf-8"))
  recvData = clientSocket.recv(1024)
  print("服務(wù)器說(shuō):%s" % (recvData.decode("utf-8"))) # 解碼:將二進(jìn)制轉(zhuǎn)換成字符

1、在TCP中,客戶端的實(shí)現(xiàn)流程:

創(chuàng)建客戶端的socket對(duì)象建立與服務(wù)器之間的聯(lián)系發(fā)送請(qǐng)求接收數(shù)據(jù)關(guān)閉連接

2、服務(wù)端的實(shí)現(xiàn)流程:

創(chuàng)建服務(wù)端的socket對(duì)象綁定服務(wù)端的地址設(shè)置監(jiān)聽(tīng)器等待客戶端的連接接收客戶端的請(qǐng)求返回處理的結(jié)果到客戶端

ThreadingTCPServer 多線程多客戶端通信自動(dòng)重連demo

socketserver繼承圖:

[外鏈圖片轉(zhuǎn)存失敗,源站可能有防盜鏈機(jī)制,建議將圖片保存下來(lái)直接上傳(img-RP9L9E1X-1577626400313)(../../../markdown_pic/blog_socketserver.png)]

TCPServer

# from socketserver import TCPServer, BaseRequestHandler, ThreadingTCPServer
from socketserver import TCPServer, StreamRequestHandler, ThreadingMixIn
import traceback

# class MyBaseRequestHandler(BaseRequestHandler):
class MyBaseRequestHandler(StreamRequestHandler):

  def handle(self):
    self.addr = self.request.getpeername()
    self.server.users[self.addr[1]] = self.request
    message = "IP " + self.addr[0] + ":" + str(self.addr[1]) + " Connected..."
    print(message)

    while True:
      try:
        data = self.request.recv(1024).decode('UTF-8', 'ignore').strip()
        print(f'receive from {self.client_address}:{data}')

        back_data = (f"response\"" + data + "\":\n").encode("utf8")
        self.request.sendall(back_data)
      except:
        traceback.print_exc()
        break

# 源碼:class ThreadingTCPServer(ThreadingMixIn, TCPServer): pass
# 從ThreadingMixIn和TCPServer繼承,實(shí)現(xiàn)多線程
class MyThreadingTCPServer(ThreadingMixIn, TCPServer):
  def __init__(self, server_address, RequestHandlerClass):
    TCPServer.__init__(self, server_address, RequestHandlerClass)
    self.users = {}


class MyTCPserver():
  def __init__(self, server_addr='192.168.1.109', server_port=23):
    self.server_address = server_addr
    self.server_port = server_port
    self.server_tuple = (self.server_address, self.server_port)

  def run(self):
    # server = TCPServer(self.server_tuple, MyBaseRequestHandler)
    server = MyThreadingTCPServer(self.server_tuple, MyBaseRequestHandler)
    server.serve_forever()


if __name__ == '__main__':
  myserver = MyTCPserver()
  myserver.run()

在telnet 下開(kāi)啟開(kāi)啟兩個(gè)客戶端,本電腦的IP為192.168.1.109,開(kāi)兩個(gè)客戶端后,TCPServer的終端出現(xiàn)同一個(gè)IP但是不同端口的連接:

[外鏈圖片轉(zhuǎn)存失敗,源站可能有防盜鏈機(jī)制,建議將圖片保存下來(lái)直接上傳(img-LRSXfXoG-1577626400318)(../../../markdown_pic/blog_TCPServer.png)]

TCPClient

import socket
import time

class MyClient:
  host = '192.168.1.109'
  port = 23
  bufsiz = 1024
  addr = None
  skt = None

  def __init__(self, host=None, port=None):
    if host != None:
      self.host = host

    if port != None:
      self.port = port

    if self.addr == None:
      self.addr = (self.host, self.port)

    self.doConnection()

  def doConnection(self):
    try:
      self.skt = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
      self.skt.setsockopt(socket.SOL_SOCKET, socket.SO_KEEPALIVE, 1)
      print(self.addr)
      self.skt.connect(self.addr)
    except:
      pass

  def run(self):
    while True:
      try:
        _time = time.strftime("%Y-%m-%d %H:%M:%S", time.localtime())
        self.skt.sendall(f'{_time}:i am clent1 '.encode('utf-8'))
        data = self.skt.recv(self.bufsiz)
        print(data.decode('utf-8', 'ignore'))
        if not data:
          break
        print(data.strip())
        time.sleep(5)
      except socket.error:
        print('socket error, reconnection') # 自動(dòng)重連
        time.sleep(3)
        self.doConnection()
      except:
        print('other error')

    self.skt.close()


myclient = MyClient()
myclient.run()

上面用的是telnet工具來(lái)作為客戶端,這里是用代碼實(shí)現(xiàn)模擬的客戶端。

在這里插入圖片描述

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • Python+Pygame實(shí)現(xiàn)之見(jiàn)縫插針游戲的實(shí)現(xiàn)

    Python+Pygame實(shí)現(xiàn)之見(jiàn)縫插針游戲的實(shí)現(xiàn)

    這篇文章主要為大家介紹了如何利用Python中的Pygame模塊實(shí)現(xiàn)見(jiàn)縫插針游戲,文中的示例代碼講解詳細(xì),對(duì)我們學(xué)習(xí)Python游戲開(kāi)發(fā)有一定幫助,需要的可以參考一下
    2022-07-07
  • Python如何在windows環(huán)境安裝pip及rarfile

    Python如何在windows環(huán)境安裝pip及rarfile

    這篇文章主要介紹了Python如何在windows環(huán)境安裝pip及rarfile,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-06-06
  • python轉(zhuǎn)換pkl模型文件為txt文件問(wèn)題

    python轉(zhuǎn)換pkl模型文件為txt文件問(wèn)題

    這篇文章主要介紹了python轉(zhuǎn)換pkl模型文件為txt文件問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2024-06-06
  • 四行Python3代碼實(shí)現(xiàn)圖片添加美顏效果

    四行Python3代碼實(shí)現(xiàn)圖片添加美顏效果

    這篇文章主要為大家介紹了如何利用Python語(yǔ)言實(shí)現(xiàn)給圖片添加美顏效果,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以跟隨小編一起了解一下
    2022-04-04
  • Python中11種NumPy高級(jí)操作總結(jié)

    Python中11種NumPy高級(jí)操作總結(jié)

    熬夜整了了11種Numpy的高級(jí)操作,每一種都有參數(shù)解釋與小例子輔助說(shuō)明。文中的示例代碼講解詳細(xì),感興趣的小伙伴快跟隨小編一起學(xué)習(xí)一下吧
    2022-05-05
  • Django中在xadmin中集成DjangoUeditor過(guò)程詳解

    Django中在xadmin中集成DjangoUeditor過(guò)程詳解

    這篇文章主要介紹了Django中在xadmin中集成DjangoUeditor過(guò)程詳解,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2019-07-07
  • 詳解在Python中創(chuàng)建條形圖追趕動(dòng)畫(huà)

    詳解在Python中創(chuàng)建條形圖追趕動(dòng)畫(huà)

    動(dòng)畫(huà)是使可視化更具吸引力和用戶吸引力的好方法。它幫助我們以有意義的方式展示數(shù)據(jù)可視化。Matplotlib是一個(gè)非常流行的數(shù)據(jù)可視化庫(kù),通常用于數(shù)據(jù)的圖形表示以及使用內(nèi)置函數(shù)的動(dòng)畫(huà)。本文將用Matplotlib繪制條形圖追趕動(dòng)畫(huà),需要的可以參考一下
    2022-03-03
  • Pytorch卷積神經(jīng)網(wǎng)絡(luò)resent網(wǎng)絡(luò)實(shí)踐

    Pytorch卷積神經(jīng)網(wǎng)絡(luò)resent網(wǎng)絡(luò)實(shí)踐

    這篇文章主要為大家介紹了Pytorch卷積神經(jīng)網(wǎng)絡(luò)resent網(wǎng)絡(luò)實(shí)踐,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-05-05
  • python3 logging日志封裝實(shí)例

    python3 logging日志封裝實(shí)例

    這篇文章主要介紹了python3 logging日志封裝實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2020-04-04
  • pandas篩選某列出現(xiàn)編碼錯(cuò)誤的解決方法

    pandas篩選某列出現(xiàn)編碼錯(cuò)誤的解決方法

    今天小編就為大家分享一篇pandas篩選某列出現(xiàn)編碼錯(cuò)誤的解決方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2018-11-11

最新評(píng)論