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

news2024/11/18 17:48:15

硬件组成体系结构

1.为什么要学操作系统

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

2.性能优化诊断方法论

(1)围绕两个点:

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

(2)性能优化方法论:

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

3.硬件组成体系结构

(1)什么是计算机

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

在这里插入图片描述

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

  • 控制器 Control Unit【CU】:计算机的指挥系统,用来控制计算机其他组件的运行。
  • 运算器 Arithmetic/Logic Unit【ALU】:运算功能,用来完成各种二进制编码做算术运算和逻辑运算,包括加减乘、与或非运算,控制器+运算器=CPU。
    • 运算器和控制器联系十分紧密,两大不见多数集成在同一个芯片中,称为中央处理器(Central Processing Unit,CPU)、
  • 存储器:计算机数据存储
    • 内存:内存条,临时存储,断电丢失数据
    • 外存:机械硬盘,持久存储,断电不丢失数据
  • IO设备:可以将数据输入到计算机,或者接收计算机输出的外部设备
    • 输入设备input:计算机接收外界输入数据的工具,比如键盘、鼠标、麦克风、触摸屏。
    • 输出设备output:计算机向外输出数据的工具,比如显示器、音响、打印机。

在这里插入图片描述

操作系统和进程

1.什么是操作系统

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

在这里插入图片描述

现代操作系统核心功能

  • 进程管理:操作系统为进程分配任务,解决处理器调度、分配和回收等。
  • 处理器管理: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进程是否正常工作

个进程,这个去创建进程称为父进程,被创建进程称为子进程

  • 应用场景:
    • Nginx的master-worker进程
    • worker是处理真正的请求的,而master负责监控worker进程是否正常工作

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/72558.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

第12章 初识消息队列(MessageQueuing)

1 Redis分布式缓存数据库结合“StackExchange.Redis”中间件实现消息队列(MessageQueuing) Redis分布式缓存数据库消息队列(MessageQueuing)队列的实现模式有: 1、【生产(Producter)】--【消费(Worker)】模式。 变种模式:【基于异步消息队列List lpush-b…

Zabbix部署agent2

客户端提前部署好 下载rpm环境 http://repo.zabbix.com/zabbix/5.0/rhel/7/x86_64/zabbix-agent2-5.0.2-1.el7.x86_64.rpm安装 [rootvpn_server opt]# yum localinstall zabbix-agent2-5.0.2-1.el7.x86_64.rpm -y# 修改配置⽂件,启动zabbix-agent2# 在zabbix-serve…

代码随想录第二天

专题:数组 题目:有序数组的平方 给你一个按 非递减顺序 排序的整数数组 nums,返回 每个数字的平方 组成的新数组,要求也按 非递减顺序 排序。 示例 2: 输入:nums [-7,-3,2,3,11] 输出:[4,9,9,…

[附源码]JAVA毕业设计外卖点餐系统(系统+LW)

[附源码]JAVA毕业设计外卖点餐系统(系统LW) 项目运行 环境项配置: Jdk1.8 Tomcat8.5 Mysql HBuilderX(Webstorm也行) Eclispe(IntelliJ IDEA,Eclispe,MyEclispe,Sts都支持)。 项目技术&…

有趣且重要的css知识合集(6)动态控制css伪元素【var()】

在vue里,js和css的属性可以随意控制,比如:class和:style,但是我们想要动态控制伪元素的属性该怎么做呢? 比如下图,右下角小圆圈就是通过伪元素定义上去的,那我们想要自由实现伪元素的显示和隐藏该怎么做呢…

如何使用 MySQL、Thymeleaf 和 Spring Boot 从数据库上传和下载多个文件

使用百里香叶的春季启动上传和下载示例。在本文中,我们将学习如何从数据库上传和下载文件。 上传和下载文件是任何应用程序的重要组成部分之一。众所周知,我们使用 Spring Boot 使开发过程变得简单。因此,在这里我们将创建一个示例来从数据库…

高通Ride开发包使用指南(1)

高通Ride开发包使用指南(1)1引言1.1目的1.2范围1.3术语2系统前提条件和设置2.1先决条件2.1.1硬件2.1.2 软件2.1.3其他所需软件:2.2布线和设置1引言 1.1目的 本文档面向高通公司Snapdragon Ride的用户™ 平台3.0(Cetus&#xff0…

点击化学DBCO-PEG8-Benzylamine,二苯并环辛炔-PEG8-苄胺标记试剂

【中文名称】二苯并环辛炔-八聚乙二醇-苄胺 【英文名称】 DBCO-PEG8-Benzylamine 【CAS号】N/A 【分子式】C42H55N3O10 【分子量】761.91 【基团】DBCO基团 【纯度】95%(HPLC) 【规格标准】1g,5g,10g,包装灵活,可进行相应的封装。…

[附源码]JAVA毕业设计微留学学生管理系统(系统+LW)

[附源码]JAVA毕业设计微留学学生管理系统(系统LW) 项目运行 环境项配置: Jdk1.8 Tomcat8.5 Mysql HBuilderX(Webstorm也行) Eclispe(IntelliJ IDEA,Eclispe,MyEclispe,Sts都支持)。 项目技…

【2022.12.08】备战春招Day3——每日一题 + 406. 根据身高重建队列

【每日一题】1812. 判断国际象棋棋盘中一个格子的颜色 题目描述 给你一个坐标 coordinates ,它是一个字符串,表示国际象棋棋盘中一个格子的坐标。下图是国际象棋棋盘示意图。 如果所给格子的颜色是白色,请你返回 true,如果是黑色…

DataX 源码调试及打包

文章目录1、源码分析2、打包3、任务测试4、job配置详解Reader(读插件)Writer(写插件)通用配置前文回顾: 《DataX 及 DataX-Web 安装使用详解》 除了前文介绍的我们可以直接安装使用外,还可以下载源码打包&…

一文解决Kubernetes 的 API 流量查看器 - Kubeshark

一、Kubeshark 是什么? Kubeshark 由 2021 年 UP9 公司开源的 K8s API 流量查看器 Mizu 发展而来,试图成为一款 K8s 全过程流量监控工具。 Kubeshark 被叫做 kubernetes 的 API 流量查看器,它提供对进出 Kubernetes 集群内容器和 pod 的所有…

[附源码]JAVA毕业设计微服务的高校二手交易平台(系统+LW)

[附源码]JAVA毕业设计微服务的高校二手交易平台(系统LW) 项目运行 环境项配置: Jdk1.8 Tomcat8.5 Mysql HBuilderX(Webstorm也行) Eclispe(IntelliJ IDEA,Eclispe,MyEclispe,Sts都支持)。 …

多线程与高并发(14)——Executor框架(线程池基础)

一、简介 线程是什么,线程是一个任务的工作单元和执行单元。我们在用线程的时候知道,要创建线程,再执行线程。如果任务多的情况呢,会有大量的创建销毁线程的资源消耗,这时候就引入了线程池的概念。 JDK5开始&#xff…

使用Maven创建Servlet项目

创建Maven项目 点击FIle, 选择new ,选择Project… 选择Maven 然后点击next. 选择自己想要创建项目的目录.点击next 引入依赖 在pom.xml中添加servlet依赖. 先书写dependencies标签.然后在 Maven中央仓库 中找到servlet的依赖.复制填写进去. 这里是我常用的一个 Maven中央仓库…

TI Lab_SRR学习_3 速度扩展_2 interChirpProcessing_RangeDPU

RangeProcDSP共分为三步,如下图所示 transfers ADCBuf data through dataIn EDMA channels in ping/pong alternate order to FFT input scratch buffer - adcDataIn.Range FFT processing is done by using DSPlib and mmwavelib APIs. FFT input data is stored in input sc…

[附源码]计算机毕业设计JAVA中青年健康管理监测系统

[附源码]计算机毕业设计JAVA中青年健康管理监测系统 项目运行 环境配置: Jdk1.8 Tomcat7.0 Mysql HBuilderX(Webstorm也行) Eclispe(IntelliJ IDEA,Eclispe,MyEclispe,Sts都支持)。 项目技术: SSM …

Python 实战分析某招聘网站数据分析岗位的招聘情况

前言 嗨喽~大家好呀,这里是魔王呐 ❤ ~ 今天案例难度指数: ☆☆☆ 准备 环境使用: Anaconda (python3.9) –>识别我们写的代码 开发工具: jupyter notebook –>代码编辑功能敲代码的工具 相关模块: seaborn pandas …

在CentOS7.9系统上安装N卡3060驱动、CUDA和离线升级gcc(4.8—>8.3)用以编译框架的过程记录

1、更换yum源 主要是在终端操作需要,在显示器界面可以直接联网解决网络问题进行软件安装或更新 """"备份原来的源""" mv /etc/yum.repos.d/ /etc/yum.repos.d.bak/ mkdir /etc/yum.repos.d vim /etc/yum.repos.d/xxx.repo &qu…

LeetCode HOT 100 —— 155.最小栈

题目 设计一个支持 push ,pop ,top 操作,并能在常数时间内检索到最小元素的栈。 实现 MinStack 类: MinStack() 初始化堆栈对象。 void push(int val) 将元素val推入堆栈。 void pop() 删除堆栈顶部的元素。 int top() 获取堆栈顶部的元素。 …