首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往
您找到你想要的搜索结果了吗?
是的
没有找到

并发与并行的区别_并发执行和并行执行

学习多线程的时候会遇到一个名词:并发。这是属于操作系统中的词汇,需要了解并发和并行的区别,从网上搜集了几种说法帮助理解。 一: 并发是指一个处理器同时处理多个任务。 并行是指多个处理器或者是多核的处理器同时处理多个不同的任务。 并发是逻辑上的同时发生(simultaneous),而并行是物理上的同时发生。 来个比喻:并发是一个人同时吃三个馒头,而并行是三个人同时吃三个馒头。 二: 并行(parallel):指在同一时刻,有多条指令在多个处理器上同时执行。就好像两个人各拿一把铁锨在挖坑,一小时后,每人一个大坑。所以无论从微观还是从宏观来看,二者都是一起执行的。

01

Linux CPU实时监控mpstat命令详解

简介 mpstat是Multiprocessor Statistics的缩写,是实时系统监控工具。其报告与CPU的一些统计信息,这些信息存放在/proc/stat文件中。在多CPUs系统里,其不但能查看所有CPU的平均状况信息,而且能够查看特定CPU的信息。mpstat最大的特点是:可以查看多核心cpu中每个计算核心的统计数据;而类似工具vmstat只能查看系统整体cpu情况。 语法 mpstat [-P {|ALL}] [internal [count]] 参数 解释 -P {|ALL} 表示监控哪个CPU, cpu在[0,cpu个数-1]中取值 internal 相邻的两次采样的间隔时间、 count 采样的次数,count只能和delay一起使用 当没有参数时,mpstat则显示系统启动以后所有信息的平均值。有interval时,第一行的信息自系统启动以来的平均信息。从第二行开始,输出为前一个interval时间段的平均信息。 实例 查看多核CPU核心的当前运行状况信息, 每2秒更新一次 mpstat  219:45:12 CPU %usr %nice %sys %iowait %irq %soft %steal %guest %idle 19:45:14 all 0.04 0.00 0.00 0.00 0.00 0.00 0.00 0.00 99.96 19:45:16 all 0.00 0.00 0.00 0.03 0.00 0.00 0.00 0.00 99.97 19:45:18 all 0.00 0.07 0.07 0.00 0.00 0.00 0.00 0.00 99.87 如果要看每个cpu核心的详细当前运行状况信息,输出如下: mpstat  -P ALL 2 19:43:58     CPU    %usr   %nice    %sys %iowait    %irq   %soft  %steal  %guest   %idle 19:43:59     all    0.00    0.00    0.04    0.00    0.00    0.00    0.00    0.00   99.96 19:43:59       0    0.00    0.00    0.00    0.00    0.00    0.00    0.00    0.00  100.00 19:43:59       1    0.00    0.00    0.00    0.00    0.00    0.00    0.00    0.00  100.00 ....... 19:43:59      13    0.99    0.00    0.00    0.00    0.00    0.00    0.00    0.00   99.01 19:43:59      14    0.00    0.00    0.00    0.00    0.00    0.00    0.00    0.00  100.00 19:43:59      15    0.00    0.00    0.00    0.00    0.00    0.00    0.00    0.00  100.00 字段的含义如下 %user      在internal时间段里,用户态的CPU时间(%),不包含nice值为负进程  (usr/total)*100 %nice      在internal时间段里,nice值为负进程的CPU时间(%)   (nice/total)*100 %sys       在internal时间段里,内核时间(%)       (system/total)*100 %iowait    在internal时间段里,硬盘IO等待时间(%) (iowait/total)*100 %irq       在internal时间段里,硬中断时间(%)     (irq/total)*100 %soft      在internal时间段里,软中断时间(%)     (softirq/total)*100 %idle      在internal时间段里,CPU除去等待磁盘IO操作外的因为任何原因而空闲的时间闲置时间(%) (idle/total)*100 计算公式如下 total_cur=user+system+nice+idle+iowait+irq+softirq total_pre=pre_user+ pre_system+ pre_nice+ pre_idle+ pre_iowait+ pre_irq+ pre_softirq user=user_cur – user_pre total=total

02
领券