进程的基本概念

这篇具有很好参考价值的文章主要介绍了进程的基本概念。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

什么是进程

简单来说, 一个运行起来的程序就是一个进程 !

进程是操作系统进行资源分配的基本单位 .

例如 : 当我们去打开QQ , 于是就在系统中形成了一个进程 .

通过任务管理器 , 可以看到这么多的进程在运行.

进程的基本概念,服务器,linux,运维

进程管理

进程多了 , 自然就要进行管理 .

所谓的管理 , 可以分为两步 :

1 . 描述一个进程 : 使用 结构体 / 类 , 把一个进程有那些信息表示出来.( 结构体 也可以称为 PCB (process control block))

2 . 组织这些进程 : 使用 一定的数据结构, 把这些 结构体/对象 放到一起.

进程中结构体有那些重要的属性 ?

1 . pid : 每个进程都有的一个唯一身份标识

2 . 内存指针 : 当前这个进程使用的内存是哪个部分.(进程运行的时候, 使用了那些内存上的资源)

3 . 文件描述符表 : 文件指的是 硬盘上存储的数据 , 进程每打开一个文件 , 就会产生一个 "文件描述符"(标识了这个被打开的文件) 一个进程可能打开很多文件 , 对应了一组文件描述符, 把这些文件描述符放到一个顺序表这样的结构里 , 就构成了 文件描述符表.(进程运行时,使用了那些硬盘上的资源)

4 . 进程调度 

  1) 进程状态 :

      进程的状态主要分为两个 : 就绪态和阻塞态 , 就绪态 : 表示该进程随时可以上cpu执行.

                                                                             阻塞态 : 该进程暂时无法上cpu执行.

  2) 进程的优先级

       进程之间的调度存在优先调度的情况 .

  3) 进程的上下文

       上下文, 就是描述了当前进程执行到哪了. 因为进程在离开cpu的时候就要把当前运行的中间结果 进行" 存档 " , 当下次进程回来 cpu 上 , 再恢复之前的 "存档" , 从上次的结果继续往后执行 .

  4) 进程的记账信息

       记账信息 : 统计了每个进程 在cpu 上执行了多久了 , 可以作为调度的参考依据 .

如何组织这些进程

操作系统使用双向链表这样的结构来组织 pcb

创建一个进程, 就是创建一个 链表的节点.

销毁一个进程, 就是把链表的节点给删除了.

遍历进程列表 , 就是在遍历链表.

并行 与 并发

程序要想运行 , 就离不开 cpu .而cpu 一时间能运行的进程数是有限的 , 因此就有了 并行与并发.

进程的基本概念,服务器,linux,运维

CPU 有一个核心数 , 我的这个电脑同时只能让8个进程工作 .

进程的基本概念,服务器,linux,运维

但是这有 100多个进程, 计算机是怎么样来运行的呢? 

并行 : 同一时间 , 两个核心 , 同时执行两个进程 , 此时这两个进程就是并行执行的 .

并发 : 一个核心, 但是有三个任务 , 它的流程是 : 先执行进程1, 执行一会儿后 , 再去执行进程2,

执行一会儿之后, 再去执行进程3. 注意!  因为cpu运算的速度非常快 , 宏观上看起来 进程 1 2 3就好像是在" 同时 "运行 .

因此说 只有 8个核心 , 也是可以完成100多个进程工作的. 通过 并行 + 并发的方式来完成. 具体是使用并行还是并发 , 完全是由操作系统自身控制的.

进程与线程

创建一个进程 / 销毁一个进程 / 调度一个进程 , 它们的成本都是很高的 , 原因就体现在资源分配上 .

资源分配往往是一个很耗时的操作.

因此说 进程是比较 "重量的" 速度慢/消耗资源多.

线程则是更轻量的进程.是因为一个进程可以包括多个线程 , 而多个线程都是一个独立的可以调度执行的" 执行流 " , (这些执行流之间本事就是并发的). 同时这些线程共用一份进程的系统资源. 也就是说 , 对于线程而言 , 系统资源是已经分配好了的 , 创建线程就省下了分配资源的开销 .

区别 : 

1 . 进程包含线程

2 . 进程有自己独立的内存空间和文件描述符表, 同一个进程中的多个线程之间共享同一份地址空间和文件描述符表.

3 . 进程是操作系统资源分配的基本单位 , 线程是操作系统调度执行的基本单位 .

4 . 进程之间具有独立性 , 一个进程挂了, 不会影响到别的进程 . 同一个进程中的多个线程之间 , 一个线程挂了 , 可能会把整个进程带走 , 影响到其他线程的 .

End....进程的基本概念,服务器,linux,运维文章来源地址https://www.toymoban.com/news/detail-552126.html

到了这里,关于进程的基本概念的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 【Linux运维】shell脚本检查服务器内存和CPU利用率

    在管理服务器时候写了一个 shell脚本,在服务上实现每天凌晨3点查系统的指定文件夹下的容量大小,如果超过10G就要删除3天前的内容,还要时刻查询内存和cpu利用率,如果超过80%就要提示用户出现过载 将以上代码保存为一个.sh文件,然后通过crontab在每天凌晨3点运行即可:

    2024年02月09日
    浏览(67)
  • Linux服务器中查看进程的四种方法

    1. 使用 ps aux 命令来查看,能以简单列表的形式显示出进程信息 ps aux 用于报告当前系统的进程状态。可以搭配kill指令随时中断、删除不必要的程序. ps 命令是最基本同时也是非常强大的进程查看命令,使用该命令可以确定有哪些进程正在运行和运行的状态、进程是否结束、进

    2024年02月02日
    浏览(42)
  • Linux网络编程:多进程 多线程_并发服务器

    文章目录: 一:wrap常用函数封装 wrap.h  wrap.c server.c封装实现 client.c封装实现 二:多进程process并发服务器 server.c服务器 实现思路 代码逻辑  client.c客户端 三:多线程thread并发服务器 server.c服务器 实现思路 代码逻辑  client.c客户端 ​​​​   read 函数的返回值 wrap.h  wrap

    2024年02月12日
    浏览(56)
  • 基于linux下的高并发服务器开发(第二章)- 2.7 进程退出、孤儿进程、僵尸进程

    ◼ 父进程运行结束,但子进程还在运行(未运行结束),这样的子进程就称为孤儿进程 (Orphan Process)。 ◼ 每当出现一个孤儿进程的时候,内核就把孤儿进程的父进程设置为 init ,而 init 进程会循环地 wait() 它的已经退出的子进程。这样,当一个孤儿进程凄凉地结束 了其生

    2024年02月16日
    浏览(55)
  • Linux服务器常见运维性能测试(1)综合跑分unixbench、superbench

    最近需要测试一批服务器的相关硬件性能,以及在常规环境下的硬件运行稳定情况,需要持续拷机测试稳定性。所以找了一些测试用例。本次测试包括在服务器的高低温下性能记录及压力测试,高低电压下性能记录及压力测试,常规环境下CPU满载稳定运行的功率记录。 这个系

    2024年02月04日
    浏览(82)
  • Linux本地部署1Panel服务器运维管理面板并实现公网访问

    1Panel 是一个现代化、开源的 Linux 服务器运维管理面板。高效管理,通过 Web 端轻松管理 Linux 服务器,包括主机监控、文件管理、数据库管理、容器管理等 下面我们介绍在Linux 本地安装1Panel 并结合cpolar 内网穿透工具实现远程访问1Panel 管理界面 执行如下命令一键安装 1Panel: 安

    2024年02月04日
    浏览(98)
  • 蓝易云:Linux系统sshd命令 – openssh服务器守护进程

    sshd是Linux系统中的一个守护进程,它提供了远程登录服务和安全的文件传输功能。以下是sshd的详细教程。 1. 安装openssh-server 在Debian/Ubuntu上安装openssh-server命令如下: sudo apt-get update sudo apt-get install openssh-server 在CentOS/RHEL上安装openssh-server命令如下: sudo yum update sudo yum install

    2024年02月16日
    浏览(49)
  • Linux高并发服务器开发---笔记1(环境搭建、系统编程、多进程)

    0613 首先这整个系列笔记属于笔记①:牛客校招冲刺集训营—C++工程师中的 第四章 笔记。 视频课链接: 视频1:Linux高并发服务器开发(40h); 视频2:第4章 项目制作与技能提升(录播)(26h30min); 视频课3: 第5章 高频考点与真题精讲(录播)中的 5.10-5.13 项目回顾 有个学

    2024年02月15日
    浏览(67)
  • [1Panel]开源,现代化,新一代的 Linux 服务器运维管理面板

    本期测评试用一下1Panel这款面板。1Panel是国内飞致云旗下开源产品。整个界面简洁清爽,后端使用GO开发,前端使用VUE的Element-Plus作为UI框架,整个面板的管理都是基于docker的,想法很先进。官方还提供了视频的使用教程,本期为大家按照本专栏的基本内容进行多方面的测评。

    2024年02月07日
    浏览(94)
  • linux 服务器进程、端口查找,nginx 配置日志查找,lsof 命令详解

    1.1 使用查看端口号对应的进程信息 方式一 : 使用netstat命令 -t:显示TCP连接 -u:显示UDP连接 -l:仅显示监听状态的连接 -n:以数字形式显示端口号,而不是以服务名称显示 通过管道符号|将netstat的输出结果传递给grep命令,用于过滤出包含指定端口号的行。 执行命令后,终端

    2024年02月04日
    浏览(63)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包