【Linux】进程概念一

简介: 【Linux】进程概念一

进程概念一

冯诺依曼体系结构

我们常见的计算机,如笔记本。我们不常见的计算机,如服务器,大部分都遵守冯诺依曼体系。

截止目前为止, 我们所认识的计算机,都是一个个的硬件组成

  • 输入设备:包括键盘,鼠标,网卡,磁盘,话筒
  • 输出设备:显示器,磁盘,网卡,声卡,音响

输入设备,输出设备称之为外围设备,外围设备一般都比较慢一些,以磁盘为例相对于内存,磁盘是比较慢的。

这里我们可以思考一下,为什么不设计如下图所示的样子呢?

这里我们可以想到木桶原理,外设的效率非常低,但是CPU效率很高,整体效率就是以外设为主的。

所以因为有了内存的存在,我们可以对数据进行预加载,CPU以后在进行数据计算的时候,根本不需要访问外设了,而是直接访问内存就可以了。

但是这里我们怎么知道哪些内容需要预加载进CPU当中,通过大量的测试发现,预加载的内容一般都是加载内容旁边的内容。

关于冯诺依曼体系的几点

  • 这里的存储器指的是内存
  • 不考虑缓存情况,这里的CPU能且只能对内存进行读写,不能访问外设(输入设备或输出设备)
  • 外设(输入或输出设备)要输入或者输出数据,也只能写入内存或者从内存读取
  • 所有的外围设备只能和内存打交道

理解:可执行程序是不是一个文件?是 -> 磁盘 -> 外设。必须先加载到内存中。

在硬件层面单机和跨机之间数据是如何流向的。

你和朋友,聊qq,你发送了一个在吗?整个信息如何在体系结构中流动的

结论:

  1. 在数据层面,一般CPU不和外设直接沟通,而是直接和内存打交道
  1. 外设只会和内存打交道

操作系统

概念

任何计算机系统都包含一个基本的程序集合,称为操作系统(OS)。笼统的理解,操作系统包括:

  • 内核(进程管理,内存管理,文件管理,驱动管理)
  • 其他程序(例如函数库,shell程序等等)

设计OS的目的

  • 与硬件交互,管理所有的软硬件资源
  • 为用户程序(应用程序)提供一个良好的执行环境

操作系统为什么对软硬件资源进行管理呢?

操作系统对下通过管理好软硬件资源(手段),对上给用户提供(安全、稳定、高效、功能丰富等)执行环境(目的)

定位

在整个计算机软硬件架构中,操作系统的定位是:一款纯正的“搞管理”的软件

操作系统,一款进行软硬件资源管理的软件

如何理解“管理”

  • 管理者和被管理者是不需要直接沟通的。对管理做建模
  • 管理的本质:对被管理对象的数据做管理

管理的本质:先描述,在组织

操作系统给我们提供良好的服务,并不代表操作系统相信我们,反而操作系统不相信任何人!

我们并不能进入操作系统来随心所欲的访问数据。

系统调用接口,其实就是操作系统设计的C函数,这里的操作系统就像银行的柜台一样,我们只能去做规定的操作。

系统调用和库函数概念

  • 在开发角度,操作系统对外会表现为一个整体,但是会暴露自己的部分接口,供上层开发使用,这部分由操作系统提供的接口,叫做系统调用
  • 系统调用在使用上,功能比较基础,对用户的要求也比较高。所以有心的开发者可以对部分系统调用进行适度封装,从而形成了库,有了库就很利于更上层的用户或者开发者进行二次开发

承上启下

那在还没有学习进程之前,操作系统是怎样进行进程管理的呢?很简单,先把进程描述起来,再把进程组织起来!

进程

基本概念

  • 课本概念:程序的一个实例,正在执行的程序等
  • 内核观点:担当分配系统资源(CPU时间,内存)的实体

什么是进程?内核关于进程的相关数据结构和当前进程的代码和数据

描述进程-PCB

  • 进程信息被放在一个叫做进程控制块的数据结构中,可以理解为进程属性的集合
  • 课本上称之为PCBLinux操作系统下的PCB是:task_struct
task_struct-PCB的一种
  • Linux当中描述进程的结构叫做task_struct
  • task_structLinux内核的一种数据结构,它会被装载到RAM(内存)里并且包含着进程的信息
task_struct内容分类
  • 标识符:描述进程的唯一标识符,用来区别其他进程
  • 状态:任务状态,退出代码,退出信号灯
  • 优先级:相对于其他进程的优先级
  • 程序计数器:程序中即将被执行的下一条指令的地址
  • 内存指针:包括程序代码和进程相关数据的指针,还有和其他进程共享的内存块的指针
  • 上下文数据:进程执行时处理器的寄存器中的数据
  • I/O状态信息:包括显示的I/O请求,分配给进程的I/O设备和被进程使用的文件列表
  • 记账信息:可能包括处理器时间总和,使用的时钟总和,时间限制,记账号等

组织进程

可以在内核源码里找到它。所有运行在系统里的进程都以task_struct链表的形式存在内核里。

查看进程

  1. 进程的信息可以通过/proc系统文件夹查看

如果需要查看pid为1的进程可以通过这种手段来查看

/proc/1

  1. 大多数信息可以通过topps这些用户工具来获取

如下代码:

我们可以通过这个代码来查看有关这个进程的信息。

ps ajx | grep test | grep -v grep

通过系统调用获取进程标识符

  • 进程id(PID)
  • 父进程id (PPID)

bash本质上也是一个进程

命令行启动的所有程序,最终都会变成进程,而该进程对应的父进程都是bash

如何创建子进程的呢?

  1. fork之后,执行流会变成2个执行流
  2. fork之后,谁先运行由调度器决定
  1. forkfork之后的代码共享,通常通过ifelse if来进行执行流分流

通过系统调用创建进程fork

关于fork介绍

  1. 在父进程当中fork会返回新创建子进程的id
  2. 在子进程当中fork会返回0
  1. 如果出现错误,返回一个负值
  • fork会有两个返回值
  • 父子进程共享代码,数据各自开辟空间,私有一份(采用临时拷贝)
  • fork通过用if来分流

使用例子:

#include <stdio.h>
#include <sys/types.h>
#include <unistd.h>
int main()
{
  int ret = fork();
  if (ret < 0) {
    perror("fork");
    return 1;
  }
  else if (ret == 0) { //child
    printf("I am child : %d!, ret: %d\n", getpid(), ret);
  }
  else { //father
    printf("I am father : %d!, ret: %d\n", getpid(), ret);
  }
  sleep(1);
  return 0;
}

进程在运行的时候,是具有独立性的!父子进程,运行的时候,也是一样的都是具有独立性的


进程 = 内核数据结构 + 进程的代码和数据


数据:当有一个执行流尝试修改数据的时候,操作系统会自动给我们当前进程触发写时拷贝


fork如何理解两个返回值的问题?


fork本质是操作系统提供的一个函数,当这个函数执行的时候会创建出一个执行流,此时就会有两个执行流,然后就会有两条return语句。


相关文章
|
7月前
|
并行计算 Linux
Linux内核中的线程和进程实现详解
了解进程和线程如何工作,可以帮助我们更好地编写程序,充分利用多核CPU,实现并行计算,提高系统的响应速度和计算效能。记住,适当平衡进程和线程的使用,既要拥有独立空间的'兄弟',也需要在'家庭'中分享和并行的成员。对于这个世界,现在,你应该有一个全新的认识。
285 67
|
6月前
|
NoSQL Linux 编译器
GDB符号表概念和在Linux下获取符号表的方法
通过掌握这些关于GDB符号表的知识,你可以更好地管理和理解你的程序,希望这些知识可以帮助你更有效地进行调试工作。
309 16
|
6月前
|
Web App开发 Linux 程序员
获取和理解Linux进程以及其PID的基础知识。
总的来说,理解Linux进程及其PID需要我们明白,进程就如同汽车,负责执行任务,而PID则是独特的车牌号,为我们提供了管理的便利。知道这个,我们就可以更好地理解和操作Linux系统,甚至通过对进程的有效管理,让系统运行得更加顺畅。
202 16
|
6月前
|
Unix Linux
对于Linux的进程概念以及进程状态的理解和解析
现在,我们已经了解了Linux进程的基础知识和进程状态的理解了。这就像我们理解了城市中行人的行走和行为模式!希望这个形象的例子能帮助我们更好地理解这个重要的概念,并在实际应用中发挥作用。
141 20
|
5月前
|
监控 Shell Linux
Linux进程控制(详细讲解)
进程等待是系统通过调用特定的接口(如waitwaitpid)来实现的。来进行对子进程状态检测与回收的功能。
125 0
|
5月前
|
存储 负载均衡 算法
Linux2.6内核进程调度队列
本篇文章是Linux进程系列中的最后一篇文章,本来是想放在上一篇文章的结尾的,但是想了想还是单独写一篇文章吧,虽然说这部分内容是比较难的,所有一般来说是简单的提及带过的,但是为了让大家对进程有更深的理解与认识,还是看了一些别人的文章,然后学习了学习,然后对此做了总结,尽可能详细的介绍明白。最后推荐一篇文章Linux的进程优先级 NI 和 PR - 简书。
185 0
|
5月前
|
存储 Linux Shell
Linux进程概念-详细版(二)
在Linux进程概念-详细版(一)中我们解释了什么是进程,以及进程的各种状态,已经对进程有了一定的认识,那么这篇文章将会继续补全上篇文章剩余没有说到的,进程优先级,环境变量,程序地址空间,进程地址空间,以及调度队列。
127 0
|
5月前
|
Linux 调度 C语言
Linux进程概念-详细版(一)
子进程与父进程代码共享,其子进程直接用父进程的代码,其自己本身无代码,所以子进程无法改动代码,平时所说的修改是修改的数据。为什么要创建子进程:为了让其父子进程执行不同的代码块。子进程的数据相对于父进程是会进行写时拷贝(COW)。
162 0
|
8月前
|
存储 Linux 调度
【Linux】进程概念和进程状态
本文详细介绍了Linux系统中进程的核心概念与管理机制。从进程的定义出发,阐述了其作为操作系统资源管理的基本单位的重要性,并深入解析了task_struct结构体的内容及其在进程管理中的作用。同时,文章讲解了进程的基本操作(如获取PID、查看进程信息等)、父进程与子进程的关系(重点分析fork函数)、以及进程的三种主要状态(运行、阻塞、挂起)。此外,还探讨了Linux特有的进程状态表示和孤儿进程的处理方式。通过学习这些内容,读者可以更好地理解Linux进程的运行原理并优化系统性能。
329 4
|
8月前
|
Linux 数据库 Perl
【YashanDB 知识库】如何避免 yasdb 进程被 Linux OOM Killer 杀掉
本文来自YashanDB官网,探讨Linux系统中OOM Killer对数据库服务器的影响及解决方法。当内存接近耗尽时,OOM Killer会杀死占用最多内存的进程,这可能导致数据库主进程被误杀。为避免此问题,可采取两种方法:一是在OS层面关闭OOM Killer,通过修改`/etc/sysctl.conf`文件并重启生效;二是豁免数据库进程,由数据库实例用户借助`sudo`权限调整`oom_score_adj`值。这些措施有助于保护数据库进程免受系统内存管理机制的影响。