一个服务器和一个客户端进行数据通信,服务器对客户端发送过来的数据进行处理计算,将计算结果返还给客户端。客户端和服务器使用udp通信。
客户端文件
import socket
import time
HOST = '127.0.0.1'
PORT = 5118
s = socket.socket(socket.AF_INET, socket.SOCK_DGRAM)
while True:
s.sendto(time.strftime('%S', time.localtime()).encode('utf-8'), (HOST, PORT))
print("从服务器发送", time.strftime('%S', time.localtime()))
data, addr = s.recvfrom(512)
if data=='zaijian':
break #停止循环
print("从服务器接收信息:", data.decode('utf-8')) #显示从服务器端接收的信息
time.sleep(1)
s.close()
服务器
import socket
import time
from multiprocessing import Manager, Process
def background_calculation(d):
while True:
d["processed"] = int(d["time"]) * 100
time.sleep(3)
if __name__ == "__main__":
with Manager() as manager:
HOST = '127.0.0.1' #定义变量HOST的初始值
PORT = 5118 #定义变量PORT的初始值
#创建socket对象s,参数分别表示地址和协议类型
s = socket.socket(socket.AF_INET, socket.SOCK_DGRAM)
s.bind((HOST, PORT)) #将套接字与地址绑定
data, address = s.recvfrom(1024) # 实现对话操作(接收/发送)
d = manager.dict()
d["processed"] = 0
d["time"] = data.decode('utf-8')
p = Process(target=background_calculation, args=(d,))
p.start()
s.sendto(str(d["processed"]).encode('utf-8'), address) # 发送信息
while True:
data, address = s.recvfrom(1024) #实现对话操作(接收/发送)
if data == b'zaijian': #当接收的数据是zaijian时
break #停止循环
d["time"] = data.decode('utf-8')
print('接收信息:', data.decode('utf-8')) #显示接收到的信息
s.sendto(str(d["processed"]).encode('utf-8'), address) #发送信息
s.close() #关闭连接
服务器端,使用multiprocessing库中Manager的dict进行不同线程间的数据交互。主线程与客户端通信,background_calculation()函数后台运算