python socket 多任务处理
client端:
import socket# 客户端 发送一个数据,再接收一个数据
from time import sleep
if __name__ == '__main__':
client = socket.socket(socket.AF_INET, socket.SOCK_STREAM) # 声明socket类型,同时生成链接对象
client.connect(('localhost', 6999)) # 建立一个链接,连接到本地的6969端口
i = 0
while i < 10:
# addr = client.accept()
# print '连接地址:', addr
msg = '你好我是客户端' # strip默认取出字符串的头尾空格
client.send(msg.encode('utf-8')) # 发送信息 python3 只接收btye流
data = client.recv(1024) # 接收来自服务端的信息,并指定接收的大小为最大1024字节
print('接受到的信息是:', data.decode()) # 输出我接收的信息
i += 1
sleep(2)
client.close() # 关闭这个链接
server端:
import socket
import threading
def thread_function(conn,addr):
while True:
try:
data = conn.recv(1024) # 接收数据
if data:
print('recive:', data.decode('utf-8')) # 打印接收到的数据
data1 = data.decode('utf-8') + '服务端'
conn.send(data1.encode('utf-8')) # 然后再发送数据
else:
print('客户端下线')
break
except ConnectionResetError:
print('关闭了正在占线的链接!')
break
conn.close()
if __name__ == '__main__':
#AF_INET:ipv4 socket.SOCK_STREAM:TCP协议
server = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
server.bind(('localhost', 6999)) # 绑定要监听的端口
server.listen(5) # 开始监听 表示可以使用五个链接排队
i = 10
while True: # conn就是客户端链接过来而在服务端为期生成的一个链接实例 循环等待链接
conn, addr = server.accept() # 等待链接,多个链接的时候就会出现问题,其实返回了两个值,一个元组 addr是IP地址+端口号
print(conn, addr)
thread1 = threading.Thread(target=thread_function,args=(conn,addr))#开启线程处理,避免阻塞
thread1.setDaemon(True)#守护主线程,主线程退出是子线程直接销毁
thread1.start()
本文详细介绍了如何使用Python的socket进行客户端与服务器之间的多任务通信,包括创建客户端连接、发送和接收消息,以及在服务器端实现并发处理。通过实例演示了如何利用线程避免阻塞,提高效率。
451

被折叠的 条评论
为什么被折叠?



