Socket
一、通信
(一)本地进程间的通信
同台机器不同进程之间的提高方式有多种如:
1.队列
2.同步(互斥锁、条件变量等)
(二)网络进程之间的通信
1.如何唯一标识一个进程(本地PID、网络IP+传输协议+端口)
2.socket(套接字)是实现不同主机进程之间的通讯方式
二、Socket编程
(一)创建Socket
语法
socket.socket(AddressFamily,Type)
- Address Family(常用):可以选择 AF_INET(用于 Internet 进程间通信) 或者 AF_UNIX(用于同一台机器进程 间通信)
- Type:套接字类型,可以是 SOCK_STREAM(流式套接字,主要用于 TCP 协议)或者 SOCK_DGRAM(数据报套接字,主要用于 UDP 协议)
import socket #python内置模块
#创建套接字(Socket) TCP协议
s1 = socket.socket(socket.AF_INET,socket.SOCK_STREAM)
#创建套接字(Socket) UDP协议
s2 = socket.socket(socket.AF_INET,socket.SOCK_DGRAM)
print(s1)
(二)基于UDP协议的Socket编程
1.UDP客户端
- (1)使用socket(),生成套接字描述符;
- (2)通过host_post 结构设置服务器地址和监听端口;
- (3)向服务器发送数据,sendto() ;
- (4)关闭套接字,close() ;
注意:传输协议选择的是UDP协议,无法保证数据的完整性和成功发送
from socket import *
#创建一个UDP协议的套接字,发送一条数据到网络上的另外一个进程
#1.创建套接字
client_socket = socket(AF_INET,SOCK_DGRAM)
#2.定义一个接受信息的目标,8080是一个目标服务器的端口,127.0.0.1是目标服务器地址
#