[Q&A] 如何唯一标识一个进程?
本地使用PID:
每个运行中的进程都有一个全局唯一的整数标识符,称为进程ID(Process ID)
。PID由内核分配,并在整个系统范围内保持唯一。
网络通信中的进程标识:
网络层
的ip地址
可以唯一标识网络中的主机
,传输层
的端口+协议
可以唯一标识主机中的应用程序(进程
),这样利用三元组(ip地址,端口,协议)
就可以标识网络的进程。
例如,TCP/IP协议中,(主机A, 端口X, TCP)就可以唯一标识主机A上监听端口X的某个TCP服务进程。
[Q&A] 如何查看PID?
shell echo $$
Unix/Linux系统中 ps -ef | grep java
Java
RuntimeMXBean runtimeMxBean = ManagementFactory.getRuntimeMXBean();
String currentPid = runtimeMxBean.getName(); // 3284@zhangziwa
String pidOnly = currentPid.split("@")[0]; // 3284
[Q&A] 服务器如何区分各个客户端?
四元组(客户端IP、客户端端口、服务器IP、服务器端口)
就可以唯一标识这次连接。
[Q&A] 进程之间如何通信?
本地的进程间
消息队列(Message Queue): 在内核中创建的消息队列发送消息。每个消息都有一个类型,接收者可以根据消息类型从队列中读取消息。
共享内存(Shared Memory): 共享内存是最快的进程间通信方式之一。需要使用同步机制来防止数据竞争。
网络进程之间
套接字(Sockets): 通过Socket建立一条两端进程间的通信信道。
远程过程调用(RPC,Remote Procedure Call): RPC为程序员提供了像调用本地函数一样调用远程机器上的函数的能力,隐藏了底层网络通信细节。例如,ONC/RPC
、gRPC
等。
Web服务: 通过HTTP/HTTPS协议,不同的进程可以作为客户端和服务端进行交互。 例如RESTful API
、SOAP Web
服务等。
消息队列中间件: 消息队列可以让分布在网络中的进程通过发布
和订阅
消息的方式进行异步通信,例如(RabbitMQ
、Apache Kafka
、ActiveMQ
等)
分布式服务框架: 微服务架构中使用的分布式服务框架如gRPC
、Thrift
、Dubbo
等。
参考:
计算机网络基础及 TCP、HTTP 协议详解
TCP三次握手与四次挥手(详解)
OSI网络模型 + TCP三次握手、四次挥手 + Socket、TCP、HTTP三者之间的区别和原理
解决端口冲突问题(查询端口占用进程并kill) 1. 查看端口占用