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

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