多線程處理Socket并發
server
#!/usr/bin/env python
import socket
import threading
server = socket.socket()
server.bind(('', 9999))
server.listen(5)
def readThread(conn, addr):
"""
創建一個新的線程,負責和一個客戶端通訊
:param conn:
:param addr:
:return:
"""
while True:
data = conn.recv(1024)
if data:
print('{}:{}'.format(addr, data))
else:
print("客戶端{}已關閉".format(addr))
break
conn.close()
while True:
print('------主線程,等待客戶端連接------')
conn, addr = server.accept()
print('創建一個新的線程,和客戶端{}通訊'.format(addr))
# 創建一個子線程,負責消息收發
client = threading.Thread(target=readThread, args=(conn, addr))
# 啟動線程
client.start()
client
#!/usr/bin/env python
# -*- coding: utf-8 -*-
import socket
# 創建套接字
s = socket.socket()
# 連接套接字,ip和端口必須是服務器上的
s.connect(('127.0.0.1', 9999))
while True:
data = input("輸入發送消息:")
if 'q' == data:
s.close()
break
s.send(data.encode())
# print('接受服務器返回的消息:', s.recv(1024))
# s.close()
多進程處理Socket并發
server
#!/usr/bin/env python
# -*- coding: utf-8 -*-
import socket
import threading
import multiprocessing
server = socket.socket()
server.bind(('', 9999))
server.listen(5)
def readProcess(conn, addr):
"""
創建一個新的線程,負責和一個客戶端通訊
:param conn:
:param addr:
:return:
"""
while True:
data = conn.recv(1024)
if data:
print('{}:{}'.format(addr, data))
else:
print("客戶端{}已關閉".format(addr))
break
conn.close()
while True:
print('------主線程,等待客戶端連接------')
conn, addr = server.accept()
print('創建一個新的進程,和客戶端{}通訊'.format(addr))
# 創建一個子進程
p = multiprocessing.Process(target=readProcess, args=(conn, addr))
p.start()
?
參考:https://blog.csdn.net/lianjiaokeji/article/details/83095187
?
更多文章、技術交流、商務合作、聯系博主
微信掃碼或搜索:z360901061

微信掃一掃加我為好友
QQ號聯系: 360901061
您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。
【本文對您有幫助就好】元
