在本地机器上的多个独立进程之间进行进程间通信,可以使用网络套接字(Socket)进行通信。下面是一个基于Python的示例代码,其中包含一个服务器进程和多个客户端进程。
首先,我们创建一个服务器进程的代码,它会监听一个指定的端口号,并接受来自客户端的连接请求。当有客户端连接成功后,服务器会将接收到的消息广播给所有连接的客户端。
# 服务器进程
import socket
import threading
# 客户端线程处理函数
def client_thread(client_socket):
while True:
try:
# 接收来自客户端的消息
data = client_socket.recv(1024)
if not data:
break
# 广播消息给所有连接的客户端
for client in clients:
client.send(data)
except:
break
# 关闭客户端连接
client_socket.close()
# 创建一个TCP套接字
server_socket = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
# 绑定监听的IP地址和端口号
server_socket.bind(('localhost', 8888))
# 监听最大连接数
server_socket.listen(10)
# 用于存储所有连接的客户端socket
clients = []
while True:
# 接受客户端连接请求
client_socket, addr = server_socket.accept()
# 将客户端socket加入到连接列表
clients.append(client_socket)
# 创建一个线程处理客户端消息
threading.Thread(target=client_thread, args=(client_socket,)).start()
接下来,我们创建一个客户端进程的代码,它会连接服务器,并发送消息给服务器。
# 客户端进程
import socket
import threading
# 客户端线程处理函数
def receive_thread(client_socket):
while True:
try:
# 接收来自服务器的消息
data = client_socket.recv(1024)
if not data:
break
print('Received:', data.decode())
except:
break
# 关闭客户端连接
client_socket.close()
# 创建一个TCP套接字
client_socket = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
# 连接服务器
client_socket.connect(('localhost', 8888))
# 创建一个线程接收服务器消息
threading.Thread(target=receive_thread, args=(client_socket,)).start()
while True:
# 读取用户输入的消息
message = input('Enter message: ')
# 发送消息给服务器
client_socket.send(message.encode())
使用以上代码,你可以在本地机器上创建一个服务器进程和多个客户端进程,它们之间可以通过网络套接字进行进程间通信。