如何唯一标识一个进程

[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/RPCgRPC等。
Web服务: 通过HTTP/HTTPS协议,不同的进程可以作为客户端和服务端进行交互。 例如RESTful APISOAP Web服务等。
消息队列中间件: 消息队列可以让分布在网络中的进程通过发布订阅消息的方式进行异步通信,例如(RabbitMQApache KafkaActiveMQ等)
分布式服务框架: 微服务架构中使用的分布式服务框架如gRPCThriftDubbo等。

在这里插入图片描述

参考:

计算机网络基础及 TCP、HTTP 协议详解
TCP三次握手与四次挥手(详解)
OSI网络模型 + TCP三次握手、四次挥手 + Socket、TCP、HTTP三者之间的区别和原理
解决端口冲突问题(查询端口占用进程并kill) 1. 查看端口占用

  • 16
    点赞
  • 18
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值