如何唯一标识一个进程

如何唯一标识一个进程

进程ID (PID):
每个运行中的进程都有一个全局唯一的整数标识符,称为进程ID(Process ID)。PID由内核分配,并在整个系统范围内保持唯一。
在shell中输入echo $$来查看当前shell的进程ID,或者使用ps命令查看所有进程及其PID。

网络通信中的进程标识:
网络层ip地址可以唯一标识网络中的主机
传输层端口+协议可以唯一标识主机中的应用程序(进程),
这样利用三元组(ip地址,端口,协议)就可以标识网络的进程。

例如,TCP/IP协议中,(主机A, 端口X, TCP)就可以唯一标识主机A上监听端口X的某个TCP服务进程。

在这里插入图片描述

服务器如何区分各个客户端?

IP地址和端口号: 四元组(客户端IP、客户端端口、服务器IP、服务器端口)就可以唯一标识这次连接。 对于TCP/IP协议,服务器通过监听特定端口,并且处理来自不同客户端IP和端口的连接请求来区分不同的客户端。
在这里插入图片描述

套接字(Socket): 在操作系统层面,当一个客户端与服务器建立连接时,服务器会为该客户端创建一个新的套接字。这个套接字包含了上述四元组信息,操作系统使用这些信息管理每个连接,使得服务器能够知道哪个响应应该发回给哪个客户端。

Session ID或Cookie: 在应用层面上,特别是Web服务中,服务器可以使用会话ID(Session ID)或者Cookie来区分不同用户。 当客户端首次连接到服务器时,服务器会给客户端生成并返回一个会话ID,之后客户端在后续请求中将这个ID随同请求头一起发送给服务器,这样服务器就能根据ID找到对应的会话状态,从而识别出不同的客户端。

身份验证令牌(Authentication Tokens): 类似于Session ID,现代Web应用和服务经常使用JSON Web Tokens (JWT) 或其他形式的身份验证令牌来进行客户端身份验证和跟踪。 客户端在经过认证后获得一个签名的令牌,随后每次请求都需要携带此令牌,服务器通过对令牌进行验证来确认客户端的身份和权限。

多路复用技术下的标识符: 在某些情况下,如HTTP/2和WebSocket等支持多路复用的协议下,即使在一个TCP连接中也可以通过流ID(Stream ID)等方式区分多个并发请求或消息,以服务于多个逻辑上的客户端操作。

在这里插入图片描述

进程之间如何通信?

本地的进程间

本地的进程间通信(IPC,Inter-Process Communication)是指在同一台计算机上的不同进程中进行数据和控制信息交换。
消息队列(Message Queue): 消息队列允许多个进程间通过在内核中创建的消息队列发送消息。每个消息都有一个类型,接收者可以根据消息类型从队列中读取消息。

共享内存(Shared Memory): 共享内存是最快的进程间通信方式之一,它让多个进程可以直接访问同一块物理内存区域,从而达到高效的数据共享。 需要使用同步机制(如信号量)来防止数据竞争。

网络进程之间

网络进程间通信(IPC,Inter-Process Communication)是指跨越不同计算机系统上的进程进行数据交换和协作。

套接字(Sockets): 在创建一个套接字之后,一个进程通常会绑定到本地IP地址和端口上,并监听来自其他进程或客户端的连接请求。另一端的进程则会发起连接至服务器指定的IP地址和端口,从而建立一条两端进程间的通信信道。

远程过程调用(RPC,Remote Procedure Call): RPC为程序员提供了像调用本地函数一样调用远程机器上的函数的能力,隐藏了底层网络通信细节。例如,ONC/RPC(开放网络计算_RPC)、gRPC等。

Web服务: 通过HTTP/HTTPS协议,不同的进程可以作为客户端和服务端进行交互 例如RESTful API、SOAP Web服务等,这些都构建在HTTP之上的应用层协议。

消息队列中间件: 消息队列(如RabbitMQ、Apache Kafka、ActiveMQ等)可以让分布在网络中的进程通过发布和订阅消息的方式进行异步通信,消息中间件负责处理网络传输和消息路由。

分布式服务框架: 微服务架构中使用的分布式服务框架如gRPC、Thrift、Dubbo等也提供了跨网络环境下的进程间通信功能。

在这里插入图片描述

参考:

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

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/639361.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

java 中 Iterator 与Iterable的作用

如果需要按照元素的自然顺序进行排序,应该使用哪个集合类? 如果需要按照元素的自然顺序进行排序,应该使用TreeSet或TreeMap集合类。 TreeSet:TreeSet 是一个有序的集合,它会使用元素的自然顺序对元素进行排序&#xf…

ip_vs 的管理以及 keepalived + lvs 案例

ip_vs 的管理 ipvsadm 与 keepalived for lvs ipvsadm 命令及参数介绍 部署和配置LVS服务会经常用到一些命令,如ipvsadm,可以使用“ipvsadm -help”命令查看使用帮助。 ipvsadm 命令的常用参数及其说明如下: # 添加虚拟服务器# 语法&#x…

PLC从HTTP服务端获取JSON文件,解析数据到寄存器

智能网关IGT-DSER集成了多种PLC协议,方便实现各种PLC与HTTP服务端之间通讯。通过网关的参数配置软件绑定JSON文件的字段与PLC寄存器地址,配置URL,即可采用POST命令,将JSON文件提交给HTTP的服务端; 服务端有返回的JSON&…

【JavaEE】认识网络的工作原理

作者主页:paper jie_博客 本文作者:大家好,我是paper jie,感谢你阅读本文,欢迎一建三连哦。 本文于《JavaEE》专栏,本专栏是针对于大学生,编程小白精心打造的。笔者用重金(时间和精力)打造&…

66 C++对象模型探索。C++编译器在什么时候给我们创建默认的构造函数?

一 前提,关于C编译器给我们生成 默认构造函数 的错误认知 传统知识认为:如果在一个类中,我们没有定义任何的构造函数,那么编译器会为我们隐式自动定义一个默认的构造函数,我们称这种构造函数为 "合成的默认构造函…

德思特方案|EMI兼容测试方案——匹配不同测试标准,准确高效!

方案背景 近场测试非常适合产品开发阶段辐射发射的EMI预兼容测试。在EMC测试中,进行辐射发射测试时,通常天线离被测物EUT很远,进行的都是远场测量。标准的远场辐射发射测试,可以准确定量的告诉我们被测件是否符合相应的EMC/EMI标…

网络工程师:新兴科技基础知识面试题(十三)

112.对区块链的理解与看法? 区块链是一种分布式的、公开透明的数据库技术,以区块的形式将交易数据进行链式连接。它通过去中心化的方式,将数据存储和交易验证的权力分散给网络中的多个节点,提供了一种安全、可信的数据交换和存储方…

case语句、case分支应用示例、函数及中断控制、字符串截取、替换、删除

1 案例1:中断及退出 1.1 问题 本案例要求编写两个Shell脚本,相关要求如下: 从键盘循环取整数(0结束)并求和,输出最终结果 1.2 方案 通过break、continue、exit在Shell脚本中实现中断与退出的功能。 e…

SpringCloudConfig+SpringCloudBus+Actuator+Git实现Eureka关键配置属性热更新(全程不重启服务)

文章目录 前言1.痛点2.解决方案3.具体实现3.1搭建热配置服务3.2编写配置文件3.3搭建版本控制仓库3.4Eureka-Client引入以下依赖3.5Eureka-Client微服务编写以下配置bootstrap.yml提前加载3.6分别编写测试Controller3.7测试效果3.8下线场景压测 4.SpringCloudBus优化 前言 在上…

vue组件间通信

Vue组件之间通信方式有哪些 一、父子组件通讯 1、props,emit 父组件可以通过props给子组件传递变量。子组件可以通过emit派发自定义事件,使父组件可以获得事件函数传递过来的形参。 2、$parent、$children、ref 父组件可以通过 c h i l d r e n 获取…

imgaug库图像增强指南(32):塑造【雪景】效果的视觉魔法

引言 在深度学习和计算机视觉的世界里,数据是模型训练的基石,其质量与数量直接影响着模型的性能。然而,获取大量高质量的标注数据往往需要耗费大量的时间和资源。正因如此,数据增强技术应运而生,成为了解决这一问题的…

我的项目管理工具TaskSaas

这次使用的技术是Python的Django框架,以及Django框架自带的前端模版语法. Open-TaskSaas: 项目、学习管理工具 项目已经开源,但我在此基础上已经开始更新Vue3Springboot版本,也希望喜欢开源和学习的小伙伴共同加入进来! 基本的样式,操作,都从线上环境可以看得到了! 首页 测…

Django(九)

1. 用户登录-Cookie和Session 什么是cookie和session? 发送HTTP请求或者HTTPS请求(无状态&短连接) http://127.0.0.1:8000/admin/list/ https://127.0.0.1:8000/admin/list/http无状态短连接:一次请求响应之后断开连接,再发请求重新连…

PCB导线阻抗概念

1. 计算公式 https://baijiahao.baidu.com/s?id1750340479004609055&wfrspider&forpc Z087/SQRT(εr1.41)ln[(5.98h)/(0.8wt)] 常规来说阻抗与介电常数成反比,与介质层厚度成正比,与线宽成反比,与铜厚成反比。 Z0:印刷导线的特性阻抗 εr:绝缘…

RK3568笔记十:Zlmediakit交叉编译

若该文为原创文章,转载请注明原文出处。 编译Zlmediakit的主要目的是想实现在RK3568拉取多路RTPS流,并通过MPP硬解码,DRM显示出来。为了实现拉取多路流选择了Zlmediakit,使用FFMEPG也可以,在RV1126上已经验证了可行性。 一、环境…

CPU和GPU的工作原理及区别

CPU(Central Processing Unit)和GPU(Graphics Processing Unit)是计算机系统中的两种主要处理器类型,它们在工作原理和用途上有一些显著的区别。 CPU(中央处理器) 工作原理: 通用…

CEF框架中的一些宏定义(一):CHECK DCHECK

文章目录 CHECK & DCHECKDCHECK_IS_ON 日志相关COMPACT_GOOGLE_LOG_FATALLogMessageLOG_STREAM(FATAL)LAZY_STREAMLogMessageVoidify 在CEF框架中,有很多的宏定义,有必要拿出来说一说,在阅读源码的时候更好的理解。 CHECK & DCHECK …

PyTorch深度学习实战(31)——生成对抗网络(Generative Adversarial Network, GAN)

PyTorch深度学习实战(31)——生成对抗网络 0. 前言1. GAN2. GAN 模型分析3. 利用 GAN 模型生成手写数字小结系列链接 0. 前言 生成对抗网络 (Generative Adversarial Networks, GAN) 是一种由两个相互竞争的神经网络组成的深度学习模型,它由…

Flask框架小程序后端分离开发学习笔记《3》客户端向服务器端发送请求

Flask框架小程序后端分离开发学习笔记《3》客户端向服务器端发送请求 Flask是使用python的后端,由于小程序需要后端开发,遂学习一下后端开发。 一、为什么请求数据需要先编码 #构造一个HTTP请求 http_request GET / HTTP/1.1\r\nhost:{}\r\n\r\n.for…

大语言模型系列-ELMo

文章目录 前言一、ELMo的网络结构和流程二、ELMo的创新点总结 前言 在前文大语言模型系列-word2vec已经提到word2vec的缺点: 为每个词汇表中每个分词静态生成一个对应的词向量表示,没有考虑到语境,因此无法无法处理多义词 ps:先…