【操作系统】操作系统硬件组成和进程

简介: 【操作系统】操作系统硬件组成和进程

硬件组成体系结构

1.为什么要学操作系统

  • 从操作系统-网络-应用程序-存储等多方面诊断和优化。
  • 比如:接口突然响应慢、服务器内存、CPU占用率高、Redis、MySQL查询慢,怎末排查问题。

2.性能优化诊断方法论

(1)围绕两个点:

应用程序性能维度 操作系统资源维度
提高吞吐量Throughput CPU使用率
降低延迟Latency 内存使用率
磁盘IO使用率

(2)性能优化方法论:

  • 选择【指标】评估系统和应用程序现状
  • 设置性能优化【目标】
  • 进行链路基准【测试】
  • 【分析】全链路性能瓶颈
  • 【优化】系统和应用程序
  • 【验证】优化后的性能指标

3.硬件组成体系结构

(1)什么是计算机

1945年-科学家冯·诺依曼提了一种计算机设计实现架构,奠定现代计算机的理论基础。


fb7a710a94b54ed2893323a3b8c37ea7.jpg

五大组成部分:运算器、控制器、存储器、输入设备、输出设备

  • 控制器 Control Unit【CU】:计算机的指挥系统,用来控制计算机其他组件的运行。
  • 运算器 Arithmetic/Logic Unit【ALU】:运算功能,用来完成各种二进制编码做算术运算和逻辑运算,包括加减乘、与或非运算,控制器+运算器=CPU。

运算器和控制器联系十分紧密,两大不见多数集成在同一个芯片中,称为中央处理器(Central Processing Unit,CPU)、

存储器:计算机数据存储

内存:内存条,临时存储,断电丢失数据

外存:机械硬盘,持久存储,断电不丢失数据

IO设备:可以将数据输入到计算机,或者接收计算机输出的外部设备

输入设备input:计算机接收外界输入数据的工具,比如键盘、鼠标、麦克风、触摸屏。

输出设备output:计算机向外输出数据的工具,比如显示器、音响、打印机。

d94f43cd24b141b2b7910adb3a14677b.jpg

操作系统和进程

1.什么是操作系统

  • 运行在计算机上最重要的一种程序,管理计算机的所有硬件和软件。
  • 用户通过系统OS来操作使用计算机硬件,属于中间层。


86d264408a324cb68d7b2a9272ec9bd7.jpg

现代操作系统核心功能

  • 进程管理:操作系统为进程分配任务,解决处理器调度、分配和回收等。
  • 处理器管理:CPU的管理和分配,比如分配进程CPU调度执行。
  • 内存管理:内存的管理和分配,比如给程序分配内存和释放内存。
  • 外存管理:持久化存储的管理和分配,比如磁盘文件写入。
  • I/O管理:输入/输出设备的管理,比如键盘输入和网络收发
  • 2.什么是进程

一个具有独立功能的程序对某个数据集在处理机上的执行过程,也是操作系统分配资源的基本单位。

(1)操作系统中给进程抽象了专门的【数据结构】

  • 称为进程控制块,Process Control Block简称 PCB
  • 在操作系统代码当中是一个结构体:struct task_struct{…}
  • 每一个进程均有一个PCB,在创建进程时建立PCB,伴随进程运行的全过程,真到进程撤销而撤销
  • (2)PCB数据结构包含进程的多数信息
  • 程序ID(PID、进程句柄):一个进程都必须对应一个唯一的PID,一般时整型数字。
  • 特征信息:一般分系统进程、用户进程、或者内核进程等。
  • 进程状态:运行、就绪、阻塞,表示进程现在的运行情况。
  • 优先级:表示获得CPU控制权的优先级大小。
  • 提供进程管理、调度所需要的信息。

(3)进程状态

  • 新建态:进程正在被创建,操作系统为进程分配资源,初始化PCB
  • 就绪态:具备运行条件,但没有空闲的CPU导致不能运行
  • 运行态:占有CPU,并在CPU上运行指令
  • 阻塞态:等待某一事件而暂时不能运行
  • 退出态:从系统中退出,操作系统回收进程拥有的资源、撤销PCB

(4)进程、线程、他们之间的关系

  • 进程:本质上是一个独立执行的程序,进程是操作系统进行资源分配和调度的基本概念,操作系统进行资源分配和资源调度的一个独立单位。

线程:是操作系统能够进行运算调度的最小单位,它被包含在进程之中,是进程中的实际运作单位,一个进程中可以并发多少个线程,每条线程执行不同的任务,切换受系统控制。

重点:

进程拥有多个线程的时候,这些线程会共享相同的虚拟内存和全局变量资源,这些资源在上下文切换时不需要修改。

同进程内的线程切换,要比多进程间的切换消耗更少的资源,所以开发中用多线程代替进程的原因

线程上下文切换的两种情况:

前后两个线程属于不同进程,此时资源不共享,线程上下文切换和进程的上下文切换一样

前后两个线程属于统一个进程。同进程虚拟内存共享,在切换的时候虚拟内存等资源就保持不动,只需要切换线程的私有数据,寄存器等不共享的数据

(5)进程创建

  • 进程一般由OS内核创建,一个进程也可以去创建另一个进程,这个去创建进程称为父进程,被创建进程称为子进程
  • 应用场景:
  • Nginx的master-worker进程
  • worker是处理真正的请求的,而master负责监控worker进程是否正常工作


相关文章
|
24天前
|
存储 调度 C++
【操作系统】进程与线程的区别及总结(非常非常重要,面试必考题,其它文章可以不看,但这篇文章最后的总结你必须要看,满满的全是干货......)
【操作系统】进程与线程的区别及总结(非常非常重要,面试必考题,其它文章可以不看,但这篇文章最后的总结你必须要看,满满的全是干货......)
48 1
|
4天前
|
存储 缓存 安全
【Linux】冯诺依曼体系结构与操作系统及其进程
【Linux】冯诺依曼体系结构与操作系统及其进程
42 1
|
5天前
|
算法 安全 调度
深入理解操作系统:进程调度与内存管理
【7月更文挑战第10天】本文将深入探讨操作系统的核心机制,即进程调度和内存管理。我们将从理论和实践的角度出发,解释这些机制如何影响系统性能和用户体验。通过分析不同的调度算法和内存分配策略,我们旨在揭示操作系统设计背后的复杂性和精妙之处。
|
14天前
|
存储 安全 Linux
深入理解操作系统:从进程管理到内存分配
【6月更文挑战第30天】在数字时代的心脏,操作系统是现代计算不可或缺的组成部分。本文将深入探讨操作系统的核心功能,包括进程管理、内存分配以及文件系统管理。我们将通过实际案例分析,揭示这些机制如何在提高计算机性能的同时保证资源的有效利用。文章旨在为读者提供对操作系统工作原理的深刻理解,并展示其在现代技术中的应用价值。
|
18天前
|
机器学习/深度学习 算法 调度
操作系统中的进程调度策略
【6月更文挑战第26天】本文将深入探讨操作系统中的核心组件之一——进程调度。我们将从进程调度的基本概念入手,分析其重要性以及如何影响系统性能。文章将介绍几种常见的进程调度算法,并通过实例展示它们在实际操作系统中的应用。我们还将讨论现代操作系统中进程调度面临的挑战和未来可能的发展方向。
|
21天前
|
存储 缓存 算法
深入理解操作系统:从进程管理到内存优化
【6月更文挑战第23天】在数字化时代,操作系统是支撑计算设备的心脏。本文将探索操作系统的核心组件,着重于进程管理和内存优化策略,揭示它们如何共同确保系统资源的高效利用和任务的顺畅执行。通过分析现代操作系统的设计哲学和技术实现,本文旨在为读者提供对操作系统内部工作原理的深刻洞察,并展示其对提高计算性能和用户体验的重要性。
|
2天前
|
Python
Python的`signal`模块提供了访问底层操作系统提供的信号机制的方式。信号是操作系统用来通知进程发生了某种情况(如用户按下Ctrl+C)的一种机制。
Python的`signal`模块提供了访问底层操作系统提供的信号机制的方式。信号是操作系统用来通知进程发生了某种情况(如用户按下Ctrl+C)的一种机制。
5 0
|
6天前
|
算法 Linux 调度
深入理解操作系统之进程调度
【7月更文挑战第9天】在数字世界的复杂舞台上,操作系统的进程调度宛如一位精心编排剧本的导演,确保每一个“演员”——即进程——都能得到恰到好处的表演机会。本文将揭开进程调度的神秘面纱,从理论到实践,详细解读其背后的原理与策略,以及它们对系统性能和用户体验所产生的深远影响。
6 0
|
7天前
|
消息中间件 Java 调度
线程和进程的区别及其在操作系统中的实现机制
线程和进程的区别及其在操作系统中的实现机制
|
7天前
|
调度 UED
操作系统中的进程调度策略
【7月更文挑战第8天】在操作系统中,进程调度是核心功能之一,它直接影响系统的性能和用户体验。本文将探讨几种常见的进程调度策略,包括它们的原理、优缺点以及适用场景,旨在为读者提供一个全面的理解框架,帮助他们根据不同的应用需求选择合适的调度策略。