IPC和RPC的区别和联系

原文地址:http://www.cnblogs.com/gsk99/archive/2010/12/13/1904541.html


进程间通信(IPC,Inter-Process Communication),指至少两个进程或线程间传送数据或信号的一些技术或方法。进程是计算机系统分配资源的最小单位。每个进程都有自己的一部分独立的系统资源,彼此是隔离的。为了能使不同的进程互相访问资源并进行协调工作,才有了进程间通信。这些进程可以运行在同一计算机上或网络连接的不同计算机上。 进程间通信技术包括消息传递、同步、共享内存和远程过程调用。 IPC是一种标准的Unix通信机制。

 

有两种类型的进程间通信(IPC)

  本地过程调用(LPC)LPC用在多任务操作系统中,使得同时运行的任务能互相会话。这些任务共享内存空间使任务同步和互相发送信息。

  远程过程调用(RPC)RPC类似于LPC,只是在网上工作。RPC开始是出现在Sun微系统公司和HP公司的运行UNIX操作系统的计算机中。

  通过IPC和RPC,程序能利用其它程序或计算机处理的进程。客户机/服务器模式计算把远程过 程调用与其它技术如消息传递一道,作为系统间通信的一种机制。客户机执行自己的任务,但靠服务器提供后端文件服务。RPC为客户机提供向后端服务器申请服 务的通信机制,如图R-4所示。如果你把客户机/服务器应用程序想作是一个分离的程序,服务器能运行数据访问部分,因为它离数据最近,客户机能运行数据表 示和与用户交互的前端部分。这样,远程过程调用可看作是把分割的程序通过网络重组的部件。LPC有时也称耦合(Coupling)机制。

  用这种方式分割程序,当用户要访问数据时就无需每次拷贝整个数据库或它的大部分程序到用户系统。其实,服务器只处理请求,甚至只执行一些数据计算,把得出的结果再发送给用户。因为当数据存放在一个地方时,数据库同步很容易实现,所以多个用户可同时访问相同的数据。
IPC(Inter-Process Communication,进程间通信)是一种用于不同进程间传递消息和共享数据的机制。在多进程系统中,各个进程之间需要相互通信来协调工作和共享资源。IPC提供了一系列的通信方式,比如管道、消息队列、共享内存、信号量等,可以方便地实现进程间的数据传输和同步。 RPC(Remote Procedure Call,远程过程调用)是一种分布式系统中的通信机制,它允许一台计算机上的程序能够调用另一台计算机上的过程(即函数)而不需要了解底层的网络细节。RPC通过封装远程调用的细节,使得各个计算机节点之间的通信变得简单和透明。 微内核是操作系统设计的一种架构风格,其核心思想是将操作系统划分为多个小的、独立的模块,把核心功能和最基本的服务放在内核中,而将其他的功能移至用户态。这种设计可以提高操作系统的可扩展性、可维护性和安全性。微内核架构中的核心服务包括进程管理、内存管理、文件系统等,而其他功能如设备驱动、网络协议等则放在用户态运行。 在这三个概念中,IPCRPC都是用于实现进程间通信的机制,不同之处在于IPC主要用于同一台计算机上的多个进程之间的通信,而RPC则主要用于跨网络的不同计算机之间的通信。微内核则是一种操作系统的设计思想,与IPCRPC有关系,因为它们都涉及到各个模块之间的通信和交互。 可以说,IPCRPC是实现微内核设计思想的基础和重要组成部分,它们为微内核架构提供了一种灵活和可扩展的通信方式,使得不同的模块可以相互交互,从而实现了操作系统的各种功能。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值