首要解决的问题是如何唯一标识一个进程,否则通信无从谈起!
在1台电脑上可以通过进程号(PID)来唯一标识一个进程,但是在网络中这是行不通的。
其实TCP/IP协议族已经帮我们解决了这个问题,网络层的“ip地址”可以唯一标识网络中的主机,而传输层
的“协议+端口”可以唯一标识主机中的应用进程(进程)。
这样利用p地址,协议,烟口就可以标识网络的进程了,网络中的进程通信就可以利用这个标志与其它进
程进行交互
注意:
socket(简称 套接字)是进程间通信的一种方式,它与其他进程间通信的一个主要不同是:
它能实现不同主机间的进程间通信,我们网络上各种各样的服务大多都是基于Socket来完成通信的
例如我们每天浏览网页、QQ聊天、收发 email等等
import socket # 1、创建tcp/udp的套接字 # socket.socket(IPV4,udp/tcp) # UDP:socket.SOCK_DGRAM # TCP:socket.SOCK_STREAM udp_socket = socket.socket(socket.AF_INET,socket.SOCK_DGRAM) #使用套接字收/发数据 #2、准备接收方的地址 #目的IP地址:127.0.0.1 #端口号:9999 dest_addr = ('127.0.0.1',9999) #3、从键盘获取数据 send_data = input("请输入要发送的数据:") #4、发送数据到指定的电脑上的指定程序中 udp_socket.sendto(send_data.encode("utf-8"),dest_addr) # 3、关闭套接字 udp_socket.close()
- 这是发送方的信息
from socket import * import Common # 1、创建套接字 udp_socket = socket(AF_INET,SOCK_DGRAM) # 2、绑定本地的相关信息,如果一个网络程序不绑定,则系统会随机分配 local_addr = ('',12138) # ip地址和端口号,ip一般不用写,表示本机的任何一个ip udp_socket.bind(local_addr) print("waiting for message...") # 3、接收数据 recv_data = udp_socket.recvfrom(1024) # 1024表示本次接收的最大字节数 # 4、recv_data这个变量中存储的是一个元组((接收到的数据),(发送方的ip,发送方的port)) recv_msg = recv_data[0] # 存储接收到的数据 send_addr = recv_data[1] # 存储发送方的地址信息 # 5、打印接收到的数据 # print("%s:%s"%(str(send_addr),recv_msg.decode("utf-8"))) print("%s:%s"%(str(send_addr),recv_msg.decode("gbk"))) # 6、关闭套接字 udp_socket.close()