进程通信
- 两个进程如果需要通信,最基本的一个前提是能够唯一的标识一个进程,在本地进程通讯中我们可以使用PID来唯一标识一个进程,但PID只在本地唯一,网络中的两个进程PID冲突几率很大,这时候,需要其他方式。
- IP层的ip地址可以唯一标识主机,而TCP层协议和端口号可以唯一标识主机的一个进程,可以利用ip地址+协议+端口号 唯一标识网络中的一个进程。
- 唯一标识网络中的进程后,它们就可以通过Socket进行通信了。
Socket
套接字Socket是应用层和传输层之间的一个抽象层,它把TCP/IP层复杂的操作抽象为几个简单的接口供应用层调用,以实现进程在网络中通信。
Socket是一种“打开-读/写-关闭”模式的实现,服务器和客户端各自维护一个“文件”,再建立连接后打开,可以向自己文件写入内容供对方读取或者读取对方内容,通讯结束时关闭文件。