Loading [MathJax]/jax/input/TeX/config.js
前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
社区首页 >专栏 >应用程序的通信成本

应用程序的通信成本

作者头像
netkiller old
发布于 2018-03-05 07:47:42
发布于 2018-03-05 07:47:42
99000
代码可运行
举报
文章被收录于专栏:NetkillerNetkiller
运行总次数:0
代码可运行

应用程序的通信成本

什么是通信

一个程序中两个以上功能相互传递信号或数据叫做通信。

什么是成本

这是是指时间成本与空间成本。 时间就是传递数据所花费的时间。空间是指传递过程耗费容量大小。

都有哪些通信方式

  1. 全局变量
  2. 线程间通信
  3. 共享内存
  4. 共享文件
  5. 管道
  6. Socket
  7. 硬件(串口,USB) 等等

全局变量

全局变量是成本最低通信方法,通过设置全局变量,在程序运行时过程中均可操作该变量,用户信号传递,数据传输。

线程间通信

线程间通信也是采用全局变量方式,通常线程库会提供一套完善的API供用户使用,它可以实现共享,锁,互斥等机制。

共享内存

共享内存是在内存中申请开辟一个区域,用于数据共享存储。

共享文件

数据存储在文件中,供多线程,多进程访问,文件可以上锁与解锁,这种方式性能最差,但对于初级开发者非常适合。 通过将文件存储在tmpfs或shm 文件系统中,可以获得不错的性能。

管道

管道是字符设备,通常是fifo(先进先出)单向通信,如果需要双工可能使用两个管道。

Socket

Socket分为 unix socket 与 tcp/udp socket. 前者只能在unix like 系统中使用。 Socket 分为阻塞与非阻塞通信。 其中tcp/udp Socket 可以跨服务器传输数据。

硬件

例如串口通信,使用串口连接两台电脑,通常速率为 9600bps,115200bps A电脑中运行

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
cat /dev/ttyS0

B电脑运行

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
cat /etc/passwd > /dev/ttyS0

可以将/etc/passwd文件从A电脑传递到B电脑。

不再本文讨论范围,这里不多述。

现在我们已经清楚了各种通信方式,这些通信方式适用于不同场景,由此出现了很多种使用方式,甚至多种方式同时使用。

服务器池概念

互联网时代的特点是,服务器不在单一一种,而是各种异构系统,我们经常会看到一个网站有多个服务器组成,因此我们将应用分布在不同的服务器上运行。 例如 Web服务器,应用服务器,缓存服务器,数据库服务器各司其职。就应用服务器还可能分成很多种类,例如搜索,内容管理,用户中心,等等。 问题来了,你会发现你的每个团队开发出一个产品,都需要一个服务器运行,每个团队都在做独立系统。不同团队开发出的功能与其他产品并不兼容,于是有了接口这种东西。 运维的问题也来了,每个应用一个服务器不太现实,但每个项目都不想与其他项目公用一个服务器资源,于是有了虚拟机

于是我们见到的系统是这样了

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
               +--------+
               | C 应用 |
               +--------+
                ^  ^  ^
                |  |  |
+--------+ <-----+  |  +-----> +--------+
| A 应用 | <--------+--------> | B 应用 |
+--------+ <-----+  |  +-----> +--------+
                 |  |  |
                 V  V  V
               +--------+
               | D 应用 |
               +--------+

A 应用 运行中会与其他三个服务器产生通信,一次操作建立三次连接,这样的通信成本是非常高的,如果任何一个节点出现故障都出现阻塞。 从运维角度这种配置也极其繁琐,每个节点都要配置与其他连点连接,防火墙ACL 维护也非常繁琐。 出现故障,排查也非常困难,还会消耗大量的排查时间。

进一步优化

我们将公共调用部门放在一处,然后将所有资源都放在服务器上。通过负载均衡分发调用,高可用技术解决公用接口单点问题。

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
               +----------+
               | 公共接口 |
               +----------+
                 ^  ^  ^
                 |  |  | 
    +------------+  |  +------------+
    |               |               |
    V           V               V
+--------+      +--------+      +--------+
| A 应用 |      | B 应用 |      | C 应用 |
| B 应用 |      | C 应用 |      | A 应用 |
| C 应用 |      | A 应用 |      | B 应用 |
+--------+      +--------+      +--------+

这样的好处显而易见,服务器节点充分使用,既有高可用,又有负载均衡,保障7*24小时无故障运行。部属也方便。 注意上面:每个节点的 A,B,C 应用 加权值不同。

耦合与解耦

耦合级别有变量级别、函数级别、方法级别、类级别、包级别、协议级别、语言级别、数据流级别、缓存级别、数据库级别、以及业务级别。 你需要根据当时场景适当耦合或解耦。例如理论上软件运行速度是在同一个实体机上运行效率最高,有时可能将其设计为分布式才能体现效率。

本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2015-10-12,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 Netkiller 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
暂无评论
推荐阅读
编辑精选文章
换一批
进程和线程的概念、区别及进程线程间通信
进程是对运行时程序的封装,是系统进行资源调度和分配的的基本单位,实现了操作系统的并发;
海盗船长
2020/08/27
37.8K0
因为没答好进程间通信,面试挂了...
结果面试过程只花了 5 分钟就结束了,面完的时候,天还是依然是亮的,还得在烈日下奔波 1 小时回去。
程序员小猿
2021/01/19
6820
因为没答好进程间通信,面试挂了...
进程通信常见方式
在操作系统中,进程之间需要进行通信以实现协作和数据共享。以下是几种常见的进程通信方式:1)管道(Pipe):管道是一种半双工的通信方式,它可以在两个进程之间传递数据。管道的特点是数据只能单向流动,而且通常只用于具有亲缘关系的进程之间进行通信,例如父子进程之间。
一个风轻云淡
2023/10/15
2.4K0
进程通信常见方式
Linux 进程间通信
进程间通信(interprocess communication,简称 IPC)指两个进程之间的通信。系统中的每一个进程都有各自的地址空间,并且相互独立、隔离,每个进程都处于自己的地址空间中,因此相互通信比较难,Linux 内核提供了多种进程间通信的机制。
Jasonangel
2022/10/25
3.3K0
Linux 进程间通信
Linux进程通信
管道是一种特殊的文件,它不属于某一种文件系统,而是一种独立的文件系统,是只存在于内存中的文件,本质是内核的一块缓冲。写入的内容每次都添加在管道缓冲区的末尾,并且每次都是从缓冲区的头部读出数据。管道是单向的、先进先出的、无结构的、固定大小字节流,它把一个进程的标准输出和另一个进程的标准输入连接在一起。
Marigold
2022/06/17
1.9K0
Linux进程通信
进程间8种通信方式详解
每个进程各自有不同的用户地址空间,任何一个进程的全局变量在另一个进程中都看不到,所以进程之间要交换数据必须通过内核,在内核中开辟一块缓冲区,进程A把数据从用户空间拷到内核缓冲区,进程B再从内核缓冲区把数据读走,内核提供的这种机制称为进程间通信。
sunsky
2020/09/01
49K0
线程通信(ITC)
通信是人的基本需求。而进程作为人的发明,自然脱离不了人的习性,也有通信需求。如果进程之间不进行任何通信,那么进程所能完成的任务就要大打折扣。 例如,父进程在创建子进程后,通常须要监督子进程的状态,以便在子进程没有完成给定的任务时,可以再创建一个子进程来继续。这就需要父子进程间通信。
全栈程序员站长
2022/09/06
7940
线程通信(ITC)
一文快速了解进程、线程与协程
进程是操作系统进行资源分配的基本单位,每个进程都有自己的独立内存空间。由于进程比较重量,占据独立的内存,所以上下文进程间的切换开销(栈、寄存器、虚拟内存、文件句柄等)比较大,但相对比较稳定安全。
全菜工程师小辉
2021/06/25
15.7K0
一文快速了解进程、线程与协程
node进程间通信
作为一名合格的程序猿/媛,对于进程、线程还是有必要了解一点的,本文将从下面几个方向进行梳理,尽量做到知其然并知其所以然:
用户8200753
2023/10/22
2730
详解操作系统之进程间通信 IPC (InterProcess Communication)
进程间通信(IPC,Inter-Process Communication),指至少两个进程或线程间传送数据或信号的一些技术或方法。
一个会写诗的程序员
2021/12/16
5.1K0
详解操作系统之进程间通信 IPC (InterProcess Communication)
计算机基础知识整理汇总(一)
(一)C++语言基础知识: (1)static关键字的作用: 1.全局静态变量 在全局变量前加上关键字static,全局变量就定义成一个全局静态变量。 静态存储区,在整个程序运行期间一直存在。 初始化:未经初始化的全局静态变量会被自动初始化为0(自动对象的值是任意的,除非他被显式初始化)。 作用域:全局静态变量在声明他的文件之外是不可见的,准确地说是从定义之处开始,到文件结尾。 2. 局部静态变量 在局部变量之前加上关键字static,局部变量就成为一个局部静态变量。 内存中的位置:静态存储区。 初始化:未经初始化的全局静态变量会被自动初始化为0(自动对象的值是任意的,除非他被显式初始化)。 作用域:作用域仍为局部作用域,当定义它的函数或者语句块结束的时候,作用域结束。但是当局部静态变量离开作用域后,并没有销毁,而是仍然驻留在内存当中,只不过我们不能再对它进行访问,直到该函数再次被调用,并且值不变。 3. 静态函数 在函数返回类型前加static,函数就定义为静态函数。函数的定义和声明在默认情况下都是extern的,但静态函数只是在声明他的文件当中可见,不能被其他文件所用。 函数的实现使用static修饰,那么这个函数只可在本cpp内使用,不会同其他cpp中的同名函数引起冲突。 warning:不要再头文件中声明static的全局函数,不要在cpp内声明非static的全局函数,如果你要在多个cpp中复用该函数,就把它的声明提到头文件里去,否则cpp内部声明需加上static修饰。 4. 类的静态成员 在类中,静态成员可以实现多个对象之间的数据共享,并且使用静态数据成员还不会破坏隐藏的原则,即保证了安全性。因此,静态成员是类的所有对象中共享的成员,而不是某个对象的成员。对多个对象来说,静态数据成员只存储一处,供所有对象共用。 5. 类的静态函数 静态成员函数和静态数据成员一样,它们都属于类的静态成员,它们都不是对象成员。因此,对静态成员的引用不需要用对象名。 (2) C++与C语言的区别: 设计思想上: C++是面向对象的语言,而C是面向过程的结构化编程语言 语法上: C++具有封装、继承和多态三种特性 C++相比C,增加多许多类型安全的功能,比如强制类型转换、 C++支持范式编程,比如模板类、函数模板等 (二)计算机操作系统: (1)进程与线程的概念,以及为什么要有进程线程,其中有什么区别,他们各自又是怎么同步的 ? 进程是对运行时程序的封装,是系统进行资源调度和分配的的基本单位,实现了操作系统的并发。 线程是进程的子任务,是CPU调度和分派的基本单位,用于保证程序的实时性,实现进程内部的并发;线程是操作系统可识别的最小执行和调度单位。每个线程都独自占用一个虚拟处理器:独自的寄存器组,指令计数器和处理器状态。每个线程完成不同的任务,但是共享同一地址空间(也就是同样的动态内存,映射文件,目标代码等等),打开的文件队列和其他内核资源。 进程与线程的区别: 1.一个线程只能属于一个进程,而一个进程可以有多个线程,但至少有一个线程。线程依赖于进程而存在。 2.进程在执行过程中拥有独立的内存单元,而多个线程共享进程的内存。(资源分配给进程,同一进程的所有线程共享该进程的所有资源。同一进程中的多个线程共享代码段(代码和常量),数据段(全局变量和静态变量),扩展段(堆存储)。但是每个线程拥有自己的栈段,栈段又叫运行时段,用来存放所有局部变量和临时变量。) 3.进程是资源分配的最小单位,线程是CPU调度的最小单位; 4.系统开销:由于在创建或撤消进程时,系统都要为之分配或回收资源,如内存空间、I/o设备等。因此,操作系统所付出的开销将显著地大于在创建或撤消线程时的开销。类似地,在进行进程切换时,涉及到整个当前进程CPU环境的保存以及新被调度运行的进程的CPU环境的设置。而线程切换只须保存和设置少量寄存器的内容,并不涉及存储器管理方面的操作。可见,进程切换的开销也远大于线程切换的开销。 5.通信:由于同一进程中的多个线程具有相同的地址空间,致使它们之间的同步和通信的实现,也变得比较容易。进程间通信IPC,线程间可以直接读写进程数据段(如全局变量)来进行通信——需要进程同步和互斥手段的辅助,以保证数据的一致性。在有的系统中,线程的切换、同步和通信都无须操作系统内核的干预 6.进程编程调试简单可靠性高,但是创建销毁开销大;线程正相反,开销小,切换速度快,但是编程调试相对复杂。 7.进程间不会相互影响 ;线程一个线程挂掉将导致整个进程挂掉 8.进程适应于多核、多机分布;线程适用于多核 。 进程间通信的方式: 进程间通信主要包括管道、系统IPC(包括消息队列、信号量、信号、共享内存等)、以及套接字so
千与编程
2023/04/28
4830
计算机基础知识整理汇总(一)
嵌入式Linux:进程间通信机制
由于每个进程都有自己独立的地址空间,不像线程共享同一地址空间,进程之间的通信需要特定的机制。
不脱发的程序猿
2024/12/10
2540
嵌入式Linux:进程间通信机制
说说进程间通信和线程间通信的几种方式及区别
对于进程来说,子进程是父进程的复制品,从父进程那里获得父进程的数据空间,堆和栈的复制品。
Vincent-yuan
2021/12/16
3.1K0
进程通信原理
全世界几十亿台电脑,连接在一起,两两通信。上海的某一块网卡送出信号,洛杉矶的另一块网卡居然就收到了,两者实际上根本不知道对方的物理位置,你不觉得这是很神奇的事情吗?
运维部落
2020/05/28
1.4K0
c++ 线程间通信方式
某一资源同时只允许一个访问者对其进行访问,具有唯一性和排它性。但互斥无法限制访问者对资源的访问顺序,即访问是无序的,线程间不需要知道彼此的存在。
全栈程序员站长
2022/11/08
1.1K0
c++ 线程间通信方式
深入探讨进程间通信的重要性:理解不同的通信机制(下)
在上一篇文章中,我们探讨了进程间通信的三种常见机制:管道、消息队列和共享内存。我们了解到,这些机制各有其特点和适用场景,可以根据实际需求选择合适的机制进行进程间通信。然而,进程间通信并不仅限于这三种方式。
努力的小雨
2023/11/18
4920
2-2.进程通信-多线程
进程同步: 并发进程在执行次序上的协调,以达到有效的资源共享和相互合作,使程序执行有可再现性。 进程互斥: 两个并行的进程A、B,如果当A进行某个操作时,B不能做这一操作,进程间的这种限制条件称为进程互斥,这是引起资源不可共享的原因。互斥是一种特殊的同步。 一、进程通信 1.进程通信的概念(是什么?): 进程通信,是指进程之间的信息交换,是操作系统内核层中比较重要的部分。 低级通信:少量数据。信号量。 高级通信:信息量大。 2.进程通信的意义(为什么?): 并发进程之间的相互通信
见贤思齊
2020/08/05
6240
2-2.进程通信-多线程
进程间通信和线程间通信的区别_有些线程包含多个进程
进程间通信 转自 https://www.cnblogs.com/LUO77/p/5816326.html
全栈程序员站长
2022/11/08
1.3K0
进程间通信和线程间通信的区别_有些线程包含多个进程
『操作系统』 进程的描述与控制 Part3 管程
管程:管程是关于共享资源的数据结构及一组针对该资源的操作过程所构成的软件模块。 管程:管理过程
风骨散人Chiam
2021/09/06
8330
多线程(五):通信
虽然一个好的设计可以最大限度地减少所需的通信量,但是在某些时候,线程之间的通信变得非常必要 (一个线程的工作是为你的应用程序工作,但是如果这个工作的结果从未被使用过,那么它有什么用处?)线程可能需要处理新的工作请求或者向应用程序的主线程报告进度。 在这些情况下,您需要一种方法来从一个线程获取信息到另一个线程。 幸运的是,线程共享相同的进程空间的事实意味着你有很多选择进行通信。
Helloted
2022/06/07
2760
相关推荐
进程和线程的概念、区别及进程线程间通信
更多 >
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档