FreeBSD 中文社区 2025 第二季度问卷调查
FreeBSD 中文社区(CFC)
VitePress 镜像站QQ 群 787969044视频教程Ⅰ视频教程Ⅱ
  • FreeBSD 从入门到追忆
  • 中文期刊
  • 状态报告
  • 发行说明
  • 手册
  • 网络文章集锦
  • 笔记本支持报告
  • Port 开发者手册
  • 架构手册
  • 开发者手册
  • 中文 man 手册
  • 文章
  • 书籍
  • FreeBSD 从入门到追忆(第三版:草稿)
  • 编辑日志
  • 目录
  • 致谢
  • 初版序言:好望角与塔吊
  • 再版序言:回到复制粘贴,面向教程本身
  • 三版序言:且有大觉而后知此其大梦也(草稿)
  • 前言
  • 第 1 章 FreeBSD 初见
    • 第 1.1 节 操作系统的历程:UNIX、Unix-like、Linux & FreeBSD
    • 第 1.2 节 FreeBSD 简史
    • 第 1.3 节 谁在使用 FreeBSD?
    • 第 1.4 节 为什么要使用 FreeBSD?
    • 第 1.5 节 Linux 用户迁移指南
    • 第 1.6 节 FreeBSD 桌面发行版
  • 第 2 章 安装 FreeBSD
    • 第 2.1 节 安装前准备(新手入门版本)
    • 第 2.2 节 FreeBSD 安装图解(新手入门版本)
    • 第 2.3 节 UNIX 基础(新手入门版本)
    • 第 2.4 节 命令行基础(新手入门版本)
    • 第 2.5 节 安装 FreeBSD——基于 VMware Workstation Pro
    • 第 2.6 节 安装 FreeBSD——基于 Virtual Box
    • 第 2.7 节 手动安装双系统(先安装 FreeBSD)
    • 第 2.8 节 手动安装双系统(后安装 FreeBSD)
    • 第 2.9 节 安装 FreeBSD——基于 Apple M1 & Parallels Desktop 20
    • 第 2.10 节 安装 FreeBSD——基于 Apple M1 & VMware Fusion Pro
    • 第 2.11 节 Qemu 安装 RISC-V FreeBSD(基于 x86 Windows)
    • 第 2.12 节 云服务器安装 FreeBSD(基于腾讯云轻量云)
    • 第 2.13 节 安装 FreeBSD——基于 Hyper-V
  • 第 3 章 包管理器与 FreeBSD 系统更新
    • 第 3.1 节 FreeBSD 镜像站现状
    • 第 3.2 节 FreeBSD 换源方式
    • 第 3.3 节 gitup 的用法
    • 第 3.4 节 通过 pkg 包管理器安装二进制包
    • 第 3.5 节 通过 Ports 以源代码方式安装软件
    • 第 3.6 节 通过 DVD 安装软件
    • 第 3.7 节 通过 freebsd-update 更新 FreeBSD
    • 第 3.8 节 通过源代码更新 FreeBSD
    • 第 3.9 节 使用 pkgbase 更新 FreeBSD
  • 第 4 章 桌面环境
    • 第 4.1 节 显卡驱动(英特尔、AMD)
    • 第 4.2 节 显卡驱动(NVIDIA)
    • 第 4.3 节 GNOME
    • 第 4.4 节 Mate
    • 第 4.5 节 Xfce
    • 第 4.6 节 Cinnamon
    • 第 4.7 节 Lumina
    • 第 4.8 节 LXQt
    • 第 4.9 节 bspwm
    • 第 4.10 节 IceWM
    • 第 4.11 节 Budgie
    • 第 4.12 节 i3wm
    • 第 4.13 节 CDE
    • 第 4.14 节 Hyprland
    • 第 4.15 节 LXDE
    • 第 4.16 节 Window Maker
    • 第 4.17 节 Fluxbox
    • 第 4.18 节 KDE6
    • 第 4.19 节 主题美化
    • 第 4.20 节 远程桌面
    • 第 4.21 节 root 登录桌面
  • 第 5 章 中文环境配置
    • 第 5.1 节 本地化环境变量
    • 第 5.2 节 Fcitx 输入法框架
    • 第 5.3 节 IBus 输入法框架
    • 第 5.4 节 五笔输入法
    • 第 5.5 节 Firefox 与 Chromium
    • 第 5.6 节 QQ(Linux 版)
    • 第 5.7 节 更换字体
    • 第 5.8 节 金山 WPS(Linux 版)
    • 第 5.9 节 压缩与解压
    • 第 5.10 节 微信(Linux 版)
  • 第 6 章 多媒体与外设
    • 第 6.1 节 声卡
    • 第 6.2 节 蓝牙
    • 第 6.3 节 打印机
    • 第 6.4 节 触摸板
    • 第 6.5 节 音频播放器
    • 第 6.6 节 视频播放器
    • 第 6.7 节 音频图形图像处理
  • 第 7 章 代理服务器
    • 第 7.1 节 HTTP 代理
    • 第 7.2 节 V2ray
    • 第 7.3 节 Mihomo(原 Clash)
    • 第 7.4 节 OpenVPN
  • 第 8 章 账户与权限
    • 第 8.1 节 sudo 与 doas
    • 第 8.2 节 用户与组
    • 第 8.3 节 用户权限
  • 第 9 章 Jail
    • 第 9.1 节 Jail 配置
    • 第 9.2 节 Jail 更新
    • 第 9.3 节 使用 Qjail 管理 Jail
  • 第 10 章 虚拟化
    • 第 10.1 节 通过 BVCP 以网页管理 BHyve
    • 第 10.2 节 使用 bhyve 安装 Windows 11(vm-bhyve)
  • 第 11 章 计算机概论
    • 第 11.1 节 存储卡参数简介与测试
    • 第 11.2 节 总线接口与协议
    • 第 11.3 节 网络基础
    • 第 11.4 节 操作系统
    • 第 11.5 节 MySQL 数据库
  • 第 12 章 引导恢复与 TTY 配置
    • 第 12.1 节 单用户模式与密码重置
    • 第 12.2 节 配置 rEFInd(双系统用)
    • 第 12.3 节 FreeBSD 中文 TTY 控制台
    • 第 12.4 节 引导界面与控制台界面
    • 第 12.5 节 Grub & UEFI 与 efibootmgr
  • 第 13 章 FreeBSD 系统管理
    • 第 13.1 节 FreeBSD src 源码概览
    • 第 13.2 节 FreeBSD 系统概览
    • 第 13.3 节 bsdconfig 系统配置工具
    • 第 13.4 节 SSH 配置与相关工具
    • 第 13.5 节 BSD init 管理服务
    • 第 13.6 节 利用脚本自动生成 BSDlibc 库文本
  • 第 14 章 网络管理
    • 第 14.1 节 TCP 堆栈
    • 第 14.2 节 WiFi
    • 第 14.3 节 USB 网络共享(USB tethering)
    • 第 14.4 节 USB 网卡 & 以太网卡
  • 第 15 章 FreeBSD 防火墙
    • 第 15.1 节 网络参数配置命令
    • 第 15.2 节 Packet Filter(PF)
    • 第 15.3 节 IPFilter(IPF)
    • 第 15.4 节 ipfirewall(IPFW)
    • 第 15.5 节 Fail2Ban(基于 IPFW、PF、IPF)
  • 第 16 章 服务器
    • 第 16.1 节 FTP 服务器
    • 第 16.2 节 MinIO 对象存储服务
    • 第 16.3 节 Gitlab-EE
    • 第 16.4 节 时间服务
    • 第 16.5 节 WildFly
    • 第 16.6 节 Rsync 同步服务
    • 第 16.7 节 Samba 服务器
    • 第 16.8 节 NFS 服务器
    • 第 16.9 节 Webmin
  • 第 17 章 网络服务器
    • 第 17.1 节 Apache
    • 第 17.2 节 Nginx
    • 第 17.3 节 PHP 8.X
    • 第 17.4 节 MySQL 5.X
    • 第 17.5 节 MySQL 8.X
    • 第 17.6 节 NextCloud——基于 PostgreSQL
    • 第 17.7 节 Telegraf+InfluxDB+Grafana 监控平台
    • 第 17.8 节 PostgreSQL 与 pgAdmin4
    • 第 17.9 节 AList
    • 第 17.10 节 prometheus 监控部署
    • 第 17.11 节 MongoDB 80
    • 第 17.12 节 Tomcat
    • 第 17.13 节 Caddy
    • 第 17.14 节 OnlyOffice(基于 PostgreSQL)
    • 第 17.15 节 Zabbix 监控(基于 PostgreSQL)
  • 第 18 章 嵌入式(树莓派、RISCV)
    • 第 18.1 节 树莓派简介与配件选用
    • 第 18.2 节 树莓派安装 FreeBSD
    • 第 18.3 节 树莓派 FreeBSD 配置
    • 第 18.4 节 树莓派与 Linux 兼容层
    • 第 18.5 节 树莓派与 OpenBSD
    • 第 18.6 节 在 RISCV 开发板上安装 OpenBSD
    • 第 18.7 节 Radxa X4(x86)
  • 第 19 章 文学故事
    • 第 19.1 节 BSD 与哲学家 George Berkeley(乔治·贝克莱)
    • 第 19.2 节 加州大学伯克利分校与“Fiat Lux”(要有光)
  • 第 20 章 游戏与科学
    • 第 20.1 节 游戏
    • 第 20.5 节 科研与专业工具
    • 第 20.6 节 我的世界(Minecraft)
  • 第 21 章 Linux 兼容层
    • 第 21.1 节 Linux 兼容层实现
    • 第 21.2 节 Linux 兼容层——基于 CentOS(FreeBSD Port)
    • 第 21.3 节 Linux 兼容层——基于 Ubuntu/Debian
    • 第 21.4 节 Linux 兼容层——基于 ArchLinux bootstrap
    • 第 21.5 节 Linux 兼容层——基于 archlinux-pacman
    • 第 21.6 节 Linux 兼容层——基于 OpenSUSE
    • 第 21.7 节 Linux 兼容层——基于 Gentoo Linux
    • 第 21.8 节 Linux 兼容层——基于 Rocky Linux
    • 第 21.9 节 Linux 兼容层——基于 Slackware Linux
    • 第 21.10 节 RockyLinux 兼容层(FreeBSD Port)
    • 第 21.11 节 Linux 兼容层——基于 Deepin
    • 第 21.12 节 Linux 兼容层与 Jail
    • 第 21.13 节 Linux 兼容层故障排除与未竟事宜
  • 第 22 章 编程环境与软件开发
    • 第 22.1 节 如何报告 Bug
    • 第 22.2 节 如何开发一个 Port
    • 第 22.3 节 如何参与 FreeBSD 开发
    • 第 22.4 节 C/C++ 环境的配置
    • 第 22.5 节 Java 环境的配置
    • 第 22.6 节 QT 环境的配置
    • 第 22.7 节 Python 与 VS Code
    • 第 22.8 节 Rust/Go 环境的配置
    • 第 22.9 节 Shell
    • 第 22.10 节 通过 IDA 7 调试 FreeBSD
    • 第 22.11 节 如何订阅 FreeBSD 的邮件列表
    • 第 22.12 节 code-server 和 clangd
    • 第 22.13 节 Node.js
  • 第 23 章 文件系统与磁盘管理
    • 第 23.1 节 自动挂载文件系统
    • 第 23.2 节 ZFS
    • 第 23.3 节 磁盘扩容
    • 第 23.4 节 NTFS & Fat32
    • 第 23.5 节 Swap 交换分区的设置
    • 第 23.6 节 Linux 文件系统
    • 第 23.7 节 ZFS 磁盘加解密
  • 第 24 章 DragonFly BSD
    • 第 24.1 节 DragonFly BSD 概述
    • 第 24.2 节 安装 DragonFly BSD
    • 第 24.3 节 配置 DragonFly BSD
  • 第 25 章 TwinCAT/BSD
    • 第 25.1 节 TwinCAT/BSD 系统安装与基本配置
    • 第 25.2 节 TwinCAT/BSD 开发环境配置
  • 第 26 章 OpenBSD
    • 第 26.1 节 OpenBSD 概述
    • 第 26.2 节 安装 OpenBSD
    • 第 26.3 节 配置 OpenBSD
    • 第 26.4 节 OpenBSD 包管理器
    • 第 26.5 节 桌面与其他软件
  • 第 27 章 NetBSD
    • 第 27.1 节 NetBSD 概述
    • 第 27.2 节 NetBSD 安装图解
    • 第 27.3 节 NetBSD 换源与包管理器
    • 第 27.4 节 桌面与中文环境常用软件
由 GitBook 提供支持
LogoLogo

FreeBSD 中文社区(CFC) 2025

在本页
  • 操作系统的概念
  • 计算机系统
  • 操作系统的定义
  • 操作系统的特征
在GitHub上编辑
导出为 PDF
  1. 第 11 章 计算机概论

第 11.4 节 操作系统

操作系统的概念

计算机系统

计算机操作系统是可以按用户的要求接受和存储信息、自动进行数据处理并输出结果信息的系统。广义上计算机操作系统包含 机械式系统 和 电子式系统 两种。在电子式系统中,可以分为模拟式和数字式两种计算机系统。

模拟式电子计算机问世较早,内部所使用的电信号模拟自然界的实际信号,因而称为模拟电信号。模拟电子计算机处理问题的精度差;所有的处理过程均需模拟电路来实现,电路结构复杂,抗外界干扰能力极差。

计算机系统包括硬件(子)系统和软件(子)系统。硬件系统是计算机赖以工作的实体。软件系统保证计算机系统按用户指定的要求工作。这两部分构成了计算机系统的资源,因此,计算机系统的资源包括两大类:硬件资源和软件资源。

中央处理器(CPU)、内存储器(又称主存,即内存)、外存储器(磁盘、磁带、CD-ROM、DVD-ROM、U 盘“USB Flash Disk”)、以及各种输入输出设备(键盘、鼠标、打印机、显示器、扫描仪、数位板等)组成了计算机硬件系统;而且各种程序和数据则组成了计算机软件系统。

软件系统(程序、数据)
硬件系统

应用软件:文字处理、图像图形处理、科学计算、视频处理.....

中央处理器(CPU)、内存储器

支撑软件:数据库、网络、多媒体....

外存储器(磁盘、CD、DVD)

系统软件:操作系统、编译程序...

输入输出设备(键盘、鼠标、显示器、扫描仪、麦克风...)

使用计算机系统处理各种问题之前、首先要有用于处理、解决相关问题的程序。这些程序的来源可以是多种多样,例如 自行开发、购买、获取开源软件 等等。

任何一个程序在计算机系统执行前,必须先要得到计算机系统的内存空间之后才能被装入内存。这些程序的执行要依靠中央处理器即(CPU)。程序在执行的过程中需要调用公共服务子程序和共享文件,还要使用各种计算机外设以及计算机内部设备,用以完成信息的输入输出。这里的中央处理器、内存空间、公共服务子程序和共享文件以及计算机外部设备等都是计算机系统中的资源。任何程序的执行都要占用计算机系统的资源。

程序对计算机资源的要求和使用时不同的,不同的用户对计算机资源的请求和使用中可能会发生冲突。例如,当一个用户使用打印机时,另外一个用户也要求使用同一台打印机。那么没有一种方法或规则对用户使用打印机的要求进行管理,肯定会引起混乱。对一台打印机的使用需要进行管理,同样,对计算机系统中的其他资源也要进行管理,进行适当地控制和协调计算机资源分配。

计算机系统中,集中了资源管理功能和而程序执行功能的一种软件,称之为操作系统。

操作系统的定义

操作系统是计算机系统中的一个系统软件,它是一些程序模块的集合:它们能有效地组织和管理计算机系统中的硬件以及软件资源,合理地组织计算机工作流程,控制程序的执行,并向用户提供各种服务功能,使用户能灵活、方便、高效地使用计算机,并使整个计算机系统能高效地运行。

从操作系统表现形式来看,操作系统是一个大型软件程序,其中有大量的为实现操作系统各项功能的软件程序,这些软件程序从设计和结构角度看,它们通常都是模块化的。有的操作系统带有内核(kernel),其内核也是由各程序模块组成。有的操作系统本身是层次化的,每个层次的程序通常也是模块化的。总结起来,操作系统是个大型软件程序,是具有各种功能的、大量程序模块的集合。

操作系统的任务其中之一就是组织和管理计算机系统中的硬件以及软件资源。在操作系统内部,为了掌控整个计算机系统的硬件和软件资源,设计了各种不同类型的表格和数据结构,或者将所有的硬件和软件资源全部加以等级,资源的名称、类型、数量、用途、完好状态及目前使用状态等所有信息。均在有关数据结构中保存,并动态地、实时地不断更新此类数据。记录数据的目的是:让操作系统根据用户对各种资源的需求情况,资源的当前分配和使用情况及有关的资源调度策略,对资源进行有效的组织和管理。

操作系统的特征

并发性

并发行性是指操作计算机系统中同时存在若干个运行的程序,这些程序在同时向前推进。

计算机程序的并发性体现在具体两个方面:用户程序与用户程序之间的并发执行。

在单处理器环境下,这些同时运行着的程序是交替在处理器上运行的。在多处理器系统环境中,多个程序的并发特征,不仅在宏观上是并发的,而且在微观层面上,(即处理器层面)程序也是并发执行的。且在分布式系统中,多个计算机的并存,使得程序的并发特征得到了更加充分的体现,因为在每个计算机上都可以有程序执行,他们共同构造了程序并发执行的景象。

共享性

共享性是指操作系统与多个用户程序共用系统中的各种资源。这种共享性是在操作系统控制下实现的。资源的共享性主要针对计算机如下几项重要资源。

中央处理器。 中央处理器是所有程序都必须使用的重要资源,操作系统必须采用合适的调度策略,对多个并发程序分配处理器资源。

内存储器。 即“内存”,任何一个程序必须首先调入内存之后才能执行。管理内存的公共使用是操作系统的重要功能之一。

外存储器。 外存储器主要用于保存各种程序和数据。这些程序和数据一般以文件的形式存储在外存储器上、外存储器是有各种类型的(如上表格所示)。这些外存储器都是为所有的程序和数据共享的,操作系统同样必须对外存储器的共享进行管理,并且保证在外存储器中所有程序和数据的完整性和正确性。

外部设备。 外部设备是供所有的用户使用的,这些用户包括操作系统、系统用户 (如管理员) 和普通用户。操作系统必须对这些用户对外设的使用要求做出管理,使所有的外部设备能够按照一定的策略被所有用户所共享。

随机性

操作系统运行是一种随机环境下进行的。这种随机环境的含义是,操作系统不能对任何所运行程序的行为及硬件设备情况做出任何事先的假定,一个有可能在任何时候向 CPU 发出中断请求。用户提交的、运行着的程序要做什么事情也无法事先知道。一般来说操作系统正处于什么状态之中是无法确切知道的,但是,随机性并不意味着操作系统不能很好地控制资源的使用及程序的运行,随机性强调了在操作系统的设计与实现要充分考虑任何的可能性。

上一页第 11.3 节 网络基础下一页第 11.5 节 MySQL 数据库

最后更新于19天前