注册 | 登录读书好,好读书,读好书!
读书网-DuShu.com
当前位置: 首页出版图书科学技术计算机/网络操作系统其他操作系统FreeBSD操作系统设计与实现

FreeBSD操作系统设计与实现

FreeBSD操作系统设计与实现

定 价:¥69.00

作 者: (美)(Marshall, K.M.)著
出版社: 人民邮电出版社
丛编项:
标 签: FreeBSD

ISBN: 9787115136855 出版时间: 2006-02-01 包装: 胶版纸
开本: 大16开 页数: 477 字数:  

内容简介

  内容简介目录内容提要本书对FreeBSD操作系统的内容结构进行了最全国、最新鲜、最权威的论述。全书共5部分14章。第一部分包括前3章,是对FreeBSD历史、设计和内核服务的综述性介绍。第二部分包括第4章和第5章,分别论述了进程管理和存储管理。第三部分第6章到第10章,详细介绍了I/O系统,包括概述、设备、本地文件系统、网络文件系统、终端系统等。第四部分是第11章到第13章,分别介绍了进程间通信、网络通信和网络协议。第五部分是第14章,介绍了启动和关机。术语表给出了本书涉及到的一些常用术语及其解释。本书既可以作为一本FreeBSD实践指南,又可作为深入研究当代可移值的开放源代码操作系统的参考书。本书适合FreeBSD操作系统技术支持人员、应用程序开发人员、系统管理员和系统程序员阅读,也可供对学习FreeBSD感兴趣的读者参考。 第一部分 综述第1章 BSD系统的历史和目标 31.1 UNIX系统的历史 31.1.1 UNIX系统的起源 31.1.2 Research小组的UNIX系统 41.1.3 AT&T UNIX System III和System V 51.1.4 伯克利软件发布(BSD) 51.1.5 UNIX无处不在 61.2 BSD和其他系统 61.3 BSD向开放源代码的转变 81.3.1 Networking Release 2 81.3.2 法律诉讼 101.3.3 4.4BSD 111.3.4 4.4BSD-Lite Release 2 111.4 FreeBSD的开发模式 121.5 参考文献 15第2章 FreeBSD设计概述 192.1 FreeBSD的功能和内核 192.2 内核结构 202.3 内核服务 222.4 进程管理 232.4.1 信号 242.4.2 进程组和会话 252.5 内存管理 252.5.1 BSD内存管理设计要点 262.5.2 内核中的内存管理 272.6 I/O系统 282.6.1 描述符与I/O 282.6.2 描述符管理 292.6.3 设备 302.6.4 套接口IPC 302.6.5 分散/聚集I/O 312.6.6 多文件系统支持 312.7 设备 322.8 文件系统 322.9 网络文件系统 352.10 终端 362.11 进程间通信 372.12 网络通信 372.13 网络实现 382.14 系统运行 382.15 复习题 382.16 参考文献 39第3章 内核服务 413.1 内核结构 413.1.1 系统进程 413.1.2 系统入口 423.1.3 运行时刻的内核结构 423.1.4 内核的入口 433.1.5 从内核返回 443.2 系统调用 443.2.1 调用结果的处理 453.2.2 从系统调用返回 453.3 陷阱和中断 463.3.1 陷阱 463.3.2 I/O设备中断 463.3.3 软件中断 473.4 时钟中断 473.4.1 统计和进程调度 483.4.2 超时 493.5 内存管理服务 503.6 时间服务 533.6.1 真实时间 533.6.2 外部表示 543.6.3 调整时间 543.6.4 时间间隔 543.7 用户、用户组和其他身份标识 553.7.1 主机标识符 573.7.2 进程组和会话 573.8 资源服务 583.8.1 进程优先级 583.8.2 资源利用 583.8.3 资源限制 593.8.4 文件系统配额 593.9 系统运行服务 593.10 复习题 603.11 参考文献 61第二部分 进程第4章 进程管理 654.1 进程管理概述 654.1.1 多程序机制 664.1.2 调度 664.2 进程状态 674.2.1 进程结构 694.2.2 线程结构 714.3 上下文切换 724.3.1 线程状态 734.3.2 底层上下文切换 734.3.3 主动上下文切换 734.3.4 同步 754.3.5 互斥同步 784.3.6 锁管理器的锁 794.3.7 其他同步 804.4 线程调度 804.4.1 4.4BSD的调度程序 814.4.2 线程调度 814.4.3 线程优先级的计算 824.4.4 线程优先级例程 834.4.5 线程运行队列和上下文切换 834.4.6 ULE调度程序 854.5 创建进程 874.6 终止进程 894.7 信号 904.7.1 信号的历史 924.7.2 发送信号 924.7.3 接收信号 944.8 进程组和会话 954.8.1 会话 964.8.2 作业控制 984.9 监管环境 994.9.1 监管环境的语义 1004.9.2 监管环境的实现 1024.9.3 监管环境的限制 1034.10 进程的调试 1044.11 复习题 1054.12 参考文献 107第5章 存储管理 1095.1 术语 1095.1.1 进程与内存 1105.1.2 调页机制 1105.1.3 替换算法 1115.1.4 工作集模型 1125.1.5 交换机制 1125.1.6 虚拟内存的优点 1125.1.7 虚拟内存的硬件要求 1135.2 FreeBSD虚拟内存系统概述 1135.3 内核的存储管理 1155.3.1 内核映射和子映射 1165.3.2 内核地址空间的分配 1175.3.3 内核的存储分配程序 1175.3.4 内核的区域存储分配程序 1195.4 进程独立拥有的资源 1215.4.1 FreeBSD的进程虚拟地址空间 1215.4.2 缺页处理 1225.4.3 映射到对象 1235.4.4 对象 1245.4.5 对象到页面 1245.5 共享存储 1255.5.1 mmap模型 1265.5.2 共享映射 1275.5.3 私有映射 1285.5.4 压缩影子链 1295.5.5 私有快照 1305.6 创建新进程 1315.6.1 保留内核资源 1315.6.2 复制用户地址空间 1325.6.3 不通过复制创建新进程 1335.7 执行一个文件 1345.8 进程地址空间的操作 1345.8.1 改变进程大小 1355.8.2 文件映射 1355.8.3 改变保护权限 1365.9 终止进程 1375.10 调页器接口 1375.10.1 vnode调页器 1395.10.2 设备调页器 1405.10.3 物理内存调页器 1415.10.4 交换调页器 1415.11 调页机制 1445.11.1 硬件高速缓存的设计 1475.11.2 页面填色 1485.12 页面替换 1505.12.1 调页参数 1515.12.2 pageout守护进程 1525.12.3 交换机制 1555.12.4 换入进程 1565.13 可移植性 1575.13.1 pmap模块的作用 1595.13.2 初始化和启动 1615.13.3 分配和释放映射 1635.13.4 改变映射的访问和固定属性 1645.13.5 管理页表的使用信息 1655.13.6 初始化物理页面 1665.13.7 管理内部数据结构 1665.14 复习题 1675.15 参考文献 168第三部分 I/O系统第6章 I/O系统概述 1736.1 从用户到设备的I/O映射 1736.1.1 设备驱动程序 1746.1.2 I/O队列 1756.1.3 中断处理 1756.2 字符设备 1756.2.1 原始设备和物理I/O 1766.2.2 面向字符的设备 1786.2.3 字符设备驱动程序的入口点 1786.3 磁盘设备 1796.3.1 块设备驱动程序的入口点 1796.3.2 磁盘I/O请求的排序 1796.3.3 磁盘标签 1806.4 描述符的管理和服务 1816.4.1 打开文件项 1826.4.2 管理描述符 1836.4.3 异步I/O 1856.4.4 文件描述符的上锁机制 1856.4.5 描述符上的多路I/O操作 1876.4.6 select调用的实现 1896.4.7 数据在内核中的转移 1916.5 虚拟文件系统的接口 1926.5.1 vnode的内容 1936.5.2 对vnode的操作 1956.5.3 路径名转换 1956.5.4 文件系统的导出服务 1966.6 与文件系统无关的服务 1976.6.1 名字缓存 1986.6.2 缓冲区管理 1996.6.3 缓冲区管理的实现 2016.7 可叠加的文件系统 2036.7.1 简单的文件系统层 2046.7.2 联合安装的文件系统 2056.7.3 其他文件系统 2076.8 复习题 2086.9 参考文献 208第7章 设备 2107.1 设备概述 2107.1.1 PC的I/O体系结构 2107.1.2 FreeBSD海量存储I/O子系统的结构 2127.1.3 设备的命名和访问 2147.2 GEOM层 2157.2.1 术语和拓扑规则 2157.2.2 改变拓扑 2177.2.3 运行 2187.2.4 拓扑的灵活性 2197.3 CAM层 2207.3.1 SCSI子系统 2207.3.2 I/O请求通过CAM子系统的路径 2217.4 ATA层 2227.5 配置设备 2237.5.1 识别设备 2267.5.2 自动配置数据结构 2277.5.3 资源管理 2317.6 复习题 2327.7 参考文献 233第8章 本地文件系统 2348.1 文件系统的分层管理 2348.2 inode的结构 2358.2.1 inode格式的变化 2378.2.2 扩展属性 2388.2.3 文件系统的新功能 2398.2.4 文件标志 2408.2.5 动态的inode 2418.2.6 管理inode 2428.3 命名 2438.3.1 目录 2448.3.2 在目录中查找名字 2458.3.3 路径名转换 2478.3.4 链接 2488.4 配额 2498.5 文件上锁 2528.6 软更新 2568.6.1 文件系统中的更新依赖 2578.6.2 依赖关系的数据结构 2608.6.3 跟踪位映射表的依赖关系 2628.6.4 跟踪inode的依赖关系 2628.6.5 跟踪直接块的依赖关系 2638.6.6 跟踪间接块的依赖关系 2648.6.7 跟踪新间接块的依赖关系 2658.6.8 跟踪新目录项的依赖关系 2668.6.9 跟踪新目录的依赖关系 2678.6.10 跟踪删除目录项时的依赖关系 2698.6.11 截短文件 2698.6.12 回收文件和目录的inode节点 2698.6.13 跟踪目录项重命名时的依赖关系 2708.6.14 跟踪删除文件时的依赖关系 2708.6.15 fsync对软更新的要求 2718.6.16 删除文件时对软更新的要求 2728.6.17 fsck对软更新的要求 2738.6.18 软更新的性能 2748.7 文件系统的快照 2758.7.1 创建文件系统快照 2758.7.2 维护文件系统快照 2778.7.3 大型文件系统的快照 2788.7.4 快照性能 2798.7.5 后台fsck 2818.7.6 用户可见的快照 2818.7.7 动态的转储 2818.8 本地文件库 2828.8.1 文件库概述 2828.8.2 用户的文件I/O 2838.9 伯克利快速文件系统 2858.9.1 伯克利快速文件系统的组成 2868.9.2 引导块 2878.9.3 优化存储空间利用率 2888.9.4 读写文件 2898.9.5 布局策略 2918.9.6 分配机制 2928.9.7 将块组成簇 2958.9.8 基于扩展的分配 2968.10 复习题 2978.11 参考文献 299第9章 网络文件系统 3039.1 历史和概述 3039.2 NFS的结构和操作 3059.2.1 NFS协议 3089.2.2 FreeBSD的NFS实现 3109.2.3 客户机/服务器的交互操作 3139.2.4 RPC的传输问题 3149.2.5 安全问题 3159.3 提高性能的技术 3169.3.1 租约 3189.3.2 崩溃恢复 3219.4 复习题 3229.5 参考文献 323第10章 终端处理 32610.1 终端处理模式 32610.2 行规程 32710.3 用户接口 32810.4 tty结构 32910.5 进程组、会话和终端控制 33110.6 C-list 33110.7 RS-232和调制解调器控制 33210.8 终端操作 33310.8.1 打开终端 33310.8.2 输出到行规程 33410.8.3 终端的输出 33510.8.4 终端的输入 33510.8.5 ioctl例程 33710.8.6 调制解调器转换 33710.8.7 关闭终端设备 33810.9 其他行规程 33810.10 复习题 33910.11 参考文献 339第四部分 进程间通信第11章 进程间通信 34311.1 进程间通信的模型 34311.2 实现的结构和概述 34711.3 内存管理 34811.3.1 mbuf 34911.3.2 存储管理算法 35111.3.3 mbuf工具例程 35211.4 数据结构 35311.4.1 通信域 35311.4.2 套接口 35411.4.3 套接口地址 35611.4.4 锁 35711.5 建立连接 35711.6 传送数据 35911.6.1 发送数据 36011.6.2 接收数据 36111.7 关闭套接口 36311.8 本地进程间通信 36411.8.1 信号量 36511.8.2 消息队列 36611.8.3 共享内存 36711.9 复习题 36811.10 参考文献 369第12章 网络通信 37012.1 内部结构 37012.1.1 数据流 37112.1.2 通信协议 37212.1.3 网络接口 37312.2 套接口到协议的接口 37712.2.1 协议的用户请求例程 37812.2.2 协议的控制输出例程 38012.3 协议到协议的接口 38012.3.1 pr_output 38112.3.2 pr_input 38112.3.3 pr_ctlinput 38112.4 协议和网络的接口 38212.4.1 发送数据包 38312.4.2 接收数据包 38312.5 路由选择 38512.5.1 内核路由选择表 38612.5.2 路由选择查找 38812.5.3 路由选择重定向 39012.5.4 路由选择表接口 39112.5.5 用户级的路由选择策略 39212.5.6 用户级路由选择接口:路由选择套接口 39212.6 缓冲和拥塞控制 39312.6.1 协议缓冲策略 39312.6.2 队列限制 39412.7 原始套接口 39412.7.1 控制块 39412.7.2 输入处理 39512.7.3 输出处理 39512.8 网络子系统的其他主题 39512.8.1 带外数据 39512.8.2 地址解析协议 39612.9 复习题 39712.10 参考文献 398第13章 网络协议 40013.1 IPv4网络协议 40013.1.1 IPv4地址 40113.1.2 广播地址 40213.1.3 组播 40313.1.4 端口与关联 40313.1.5 协议控制块 40313.2 UDP协议 40413.2.1 初始化 40513.2.2 输出 40513.2.3 输入 40613.2.4 控制操作 40713.3 Internet协议(IP) 40713.3.1 输出 40813.3.2 输入 40913.3.3 转发 41013.4 TCP协议 41013.4.1 TCP连接状态 41213.4.2 序号变量 41513.5 TCP算法 41613.5.1 定时器 41713.5.2 往返时间的估计 41813.5.3 建立连接 41913.5.4 SYN缓存 42113.5.5 关闭连接 42113.6 TCP输入处理 42213.7 TCP输出处理 42513.7.1 发送数据 42513.7.2 避免糊涂窗口综合症 42613.7.3 避免小数据包 42713.7.4 确认延迟和窗口更新 42713.7.5 重发状态 42813.7.6 慢启动 42813.7.7 源拥塞的处理 43013.7.8 缓冲与窗口大小分配 43013.7.9 使用慢启动避免拥塞 43113.7.10 快速重发 43213.8 ICMP协议 43313.9 IPv6 43413.9.1 IPv6地址 43513.9.2 IPv6数据包格式 43713.9.3 套接口API的调整 43813.9.4 自动配置 43913.10 安全 44213.10.1 IPSec概述 44213.10.2 安全协议 44413.10.3 密钥管理 44613.10.4 IPSec实现 44913.10.5 密码子系统 45113.11 复习题 45213.12 参考文献 454第五部分 系统运行第14章 启动和关机 46114.1 概述 46114.2 引导 46214.3 初始化内核 46314.4 初始化内核模块 46414.4.1 基本服务 46514.4.2 初始化内核线程 46614.4.3 初始化设备模块 46714.4.4 内核的可加载模块 46814.4.5 启动进程间通信 46914.4.6 启动内核线程 47014.5 用户级初始化 47014.5.1 /sbin/init 47114.5.2 系统的启动脚本 47114.5.3 /usr/libexec/getty 47214.5.4 /usr/bin/login 47214.6 系统运行 47214.6.1 内核的配置 47214.6.2 系统关机与自动重启 47314.6.3 系统调试 47414.6.4 同内核传递信息 47414.7 复习题 47614.8 参考文献 476术语表 477

作者简介

  MarshallKirkMcKusick撰写了许多书籍和文章,指导和讲授UNIx和.BSD方面的课程。他在加州大学伯克利分校的时候实现了4.2BSD的快速文件系统,作为CSRG的计算机研究专家(ResearchComputer·Scientist),他见证了4.3BSD和4.4BSD的研发和发布历程。他特别感兴趣的研究领域是虚拟内存系统和文件系统。他从康奈尔大学(CoraaellUniversity)获得电子工程专业学士学位,后又进入加州大学伯克利分校开展研究生阶段的工作,并且获得计算机科学硕士学位和工商管理硕士学位,以及计算机科学博士学位。他曾两次担任UsenixAssociation的主席,目前是ACM的Queue杂志编委会成员,以及UsenixAssocation、ACM和IEEE的会员。他在业余时间喜欢游泳、潜水,还喜欢收藏葡萄酒。他的葡萄酒都储藏在一个专门建造的酒窖里(读者朋友可以从网站http:Hwww.McKusick.com/cgi.bin/readhouse上看到它),酒窖位于房子的地下室里,而上面的房子属于他和他25年的亲密伙伴EricAllmanl共同拥

图书目录

第一部 分综述
第1章 BSD系统的历史和目标
1.1 UNIX系统的历史
1.1.1 UNIX系统的起源·
1.1.2 Research小组的UNIX系统
1.1.3 AT&TUNIXSystemIII和SystemV
1.1.4 伯克利软件发布(BSD)
1.1.5 UNIX无处不在
1.2 BSD和其他系统·
1.3 BSD向开放源代码的转变
1.3.1 NetworkingRelease2
1.3.2 法律诉讼
1.3.3 4.4BSD·-·
1.3.4 4.4BSD.LiteRelease2
1.4 FreeBSD的开发模式
1.5 参考文献
第2章 FreeBSD设计概述
2.1 FreeBSD的功能和内核
2.2 内核结构
2.3 内核服务
2.4 进程管理
2.4.1 信号
2.4.2 进程组和会话
2.5 内存管理
2.5.1 BSD内存管理设计要点
2.5.2 内核中的内存管理
2.6 I/O系统
2.6.1 描述符与I/O
2.6.2 描述符管理
2.6.3 设备
2.6.4 套接口IPC
2.6.5 分散/聚集i/0
2.6.6 多文件系统支持
2.7 设备
2.8 文件系统
2.9 网络文件系统
2.10 终端
2.1l 进程问通信
2.12 网络通信
2.13 网络实现
2.14 系统运行
2.15 复习题
2.16 参考文献
第3章 内核服务
3.1 内核结构
3.1.1 系统进程
3.1.2 系统入口
3.1.3 运行时刻的内核结构
3.1.4 内核的入口
3.1.5 从内核返回
3.2 系统调用
3.2.1 调用结果的处理
3.2.2 从系统调用返回
3.3 陷阱和中断
3.3.1 陷阱
3.3.2 I/O设备中断
3.3.3 软件中断
3.4 时钟中断
3.4.1 统计和进程调度
3.4.2 超时
3.5 内存管理服务
3.6 时间服务
3.6.1 真实时间
3.6.2 外部表示
3.6.3 调整时间
3.6.4 时间间隔
3.7 用户、用户组和其他身份标识
3.7.1 主机标识符
3.7.2 进程组和会话
3.8 资源服务
3.8.1 进程优先级
3.8.2 资源利用
3.8.3 资源限制
3.8.4 文件系统配额
3.9 系统运行服务
3.10 复习题
3.11 参考文献
第二部分 进程
第4章 进程管理
4.1 进程管理概述
4.1.1 多程序机制
4.1.2 调度
4.2 进程状态
4.2.1 进程结构
4.2.2 线程结构
4.3 上下文切换
4.3.1 线程状态
4.3.2 底层上下文切换
4.3.3 主动上下文切换
4.3.4 同步
4.3.5 互斥同步
4.3.6 锁管理器的锁
4.3.7 其他同步
4.4 线程调度
4.4.1 4.4BSD的调度程序
4.4.2 线程调度
4.4.3 线程优先级的计算
4.4.4 线程优先级例程
4.4.5 线程运行队列和上下文切换
4.4.6 ULE调度程序
4.5 创建进程
4.6 终止进程
4.7 信号
4.7.1 信号的历史
4.7.2 发送信号
4.7.3 接收信号
4.8 进程组和会话
4.8.1 会话
4.8.2 作业控制
4.9 监管环境
4.9.1 监管环境的语义
4.9.2 监管环境的实现
4.9.3 监管环境的限制
4.10 进程的调试
4.11 复习题
4.12 参考文献
第5章 存储管理
5.1 术语
5.1.1 进程与内存
5.1.2 调页机制
5.1.3 替换算法
5.1.4 工作集模型
5.1.5 交换机制
5.1.6 虚拟内存的优点
5.1.7 虚拟内存的硬件要求
5.2 FreeBSD虚拟内存系统概述
5.3 内核的存储管理
5.3.1 内核映射和子映射
5.3.2 内核地址空间的分配
5.3.3 内核的存储分配程序
5.3.4 内核的区域存储分配程序
5.4 进程独立拥有的资源
5.4.1 FreeBSD的进程虚拟地址空间
5.4.2 缺页处理
5.4.3 映射到对象
5.4.4 对象
5.4.5 对象到页面
5.5 共享存储
5.5.1 mmap模型
5.5.2 共享映射
5.5.3 私有映射
5.5.4 压缩影子链
5.5.5 私有快照
5.6 创建新进程
5.6.1 保留内核资源
5.6.2 复制用户地址空间
5.6.3 不通过复制创建新进程
5.7 执行一个文件
5.8 进程地址空间的操作
5.8.1 改变进程大小
5.8.2 文件映射
5.8.3 改变保护权限
5.9 终止进程
5.10 调页器接口
5.10.1 vnode调页器
5.10.2 设备调页器
5.10.3 物理内存调页器
5.10.4 交换调页器
5.11 调页机制
5.11.1 硬件高速缓存的设计
5.11.2 页面填色
5.12 页面替换
5.12.1 调页参数
5.12.2 pageout守护进程
5.12.3 交换机制
5.12.4 换入进程
5.13 可移植性
5.13.1 pmap模块的作用
5.13.2 初始化和启动
5.13.3 分配和释放映射
5.13.4 改变映射的访问和固定属性
5.13.5 管理页表的使用信息
5.13.6 初始化物理页面
5.13.7 管理内部数据结构
5.14 复习题
5.15 参考文献
第三部分 I/O系统
第6章 I/O系统概述
6.1 从用户到设备的I/O映射
6.1.1 设备驱动程序
6.1.2 I/O队列
6.1.3 中断处理
6.2 字符设备
6.2.1 原始设备和物3EI/O
6.2.2 面向字符的设备
6.2.3 字符设备驱动程序的入口点
6.3 磁盘设备
6.3.1 块设备驱动程序的入口点
6.3.2 磁盘I/O请求的排序
6.3.3 磁盘标签
6.4 描述符的管理和服务
6.4.1 打开文件项
6.4.2 管理描述符
6.4.3 异步I/O
6.4.4 文件描述符的上锁机制
6.4.5 描述符上的多路I/0操作
6.4.6 select调用的实现·
6.4.7 数据在内核中的转移
6.5 虚拟文件系统的接口
6.5.1 vnode的内容
6.5.2 对vnode的操作
6.5.3 路径名转换
6.5.4 文件系统的导出服务
6.6 与文件系统无关的服务
6.6.1 名字缓存
6.6.2 缓冲区管理
6.6.3 缓冲区管理的实现
6.7 可叠加的文件系统
6.7.1 简单的文件系统层
6.7,2 联合安装的文件系统
6.7.3 其他文件系统
6.8 复习题一
6.9 参考文献
第7章 设备
7.1 设备概述一
7.1.1 PC的I/O体系结构
7.1.2 FreeBSD海量存储I/O子
系统的结构
7.1-3 设备的命名和访问一
7.2 GEOM层
7.2.1 术语和拓扑规则·
7.2.2 改变拓扑
7.2.3 运行
7.2.4 拓扑的灵活性
7.3 CAM层
7.3.1 SCSI子系统
7.3.2 I/O请求通过CAM子系统的路径
7.4 ATA层
7.5 配置设备
7.5.1 识别设备
7.5.2 自动配置数据结构·
7.5.3 资源管理
7.6 复习题
7.7 参考文献
第8章 本地文件系统
8.1 文件系统的分层管理
8.2 inode的结构
8.2.1 inode格式的变化
8.2.2 扩展属性
8.2.3 文件系统的新功能·
8.2.4 丈件标志·
8.2.5 动态的inode
8.2.6 管理inode
8.3 命名
8.3.1 目录
8.3.2 在目录中查找名字一
8.3.3 路径名转换
8.3.4 链接
8.4 配额
8.5 文件上锁·
8.6 软更新
8.6.1 文件系统中的更新依赖
8.6.2 依赖关系的数据结构
8.6.3 跟踪位映射表的依赖关系
8.6.4 跟踪inode的依赖关系一
8.6.5 跟踪直接块的依赖关系
8.6.6 跟踪间接块的依赖关系
8.6.7 跟踪新间接块的依赖关系
8.6,8 跟踪新目录项的依赖关系
8.6.9 跟踪新目录的依赖关系
8.6.10 跟踪删除目录项时的依赖关系
8.6.11 截短文件
8.6.12 回收文件和目录的inode节点
8.6.13 跟踪目录项重命名时的依赖关系
8.6.14 跟踪删除文件时的依赖关系
8,6.15 fsync对软更新的要求
8.6.16 删除文件时对软更新的要求
8.6.17 fsck对软更新的要求
8.6.18 软更新的性能
8.7 文件系统的快照
8.7.1 创建文件系统快照
8.7.2 维护文件系统快照
8.7.3 大型文件系统的快照
8.7.4 快照性能
8.7.5 后台fsck
8.7.6 用户可见的快照
8.7.7 动态的转储
8.8 本地文件库
8.8.1 文件库概述
8.8.2 用户的文件I/O
8.9 伯克利快速文件系统
8.9.1 伯克利快速文件系统的组成
8.9.2 引导块
8.9.3 优化存储空间利用率
8.9.4 读写文件
8.9.5 布局策略
8.9.6 分配机制
8.9.7 将块组成簇
8.9.8 基于扩展的分配
8.10 复习题
8.11 参考文献
第9章 网络文件系统
9.1 历史和概述.
9.2 NFS的结构和操作
9.2.1 NFS协议
9.2.2 FreeBSD的NFS实现
9.2.3 客户机/服务器的交互操作
9.2.4 RPC的传输问题
9.2.5 安全问题
9.3 提高性能的技术
9.3.1 租约
9.3.2 崩溃恢复
9.4 复习题
9.5 参考文献
第l0章 终端处理
10.1 终端处理模式
10.2 行规程
10.3 用户接口
10.4 tty结构·
10.5 进程组、会话和终端控制
10.6 C-1ist
10.7 RS-232和调制解调器控制
10.8 终端操作
10.8.1 打开终端
10.8.2 输出到行规程
10.8.3 终端的输出
10.8.4 终端的输入
10.8.5 ioctl例程
10.8.6 调制解调器转换
10.8.7 关闭终端设备
10.9 其他行规程
10.10 复习题
10.11 参考文献
第四部分 进程间通信
第11章 进程间通信
11.1 进程问通信的模型
11.2 实现的结构和概述
1l.3 内存管理
11.3.1 mbuf
11.3.2 存储管理算法·
11.3.3 mbuf工具例程
11.4 数据结构
11.4.1 通信域
11.4.2 套接口
11.4.3 套接口地址
11.4.4 锁
11.5 建立连接
11.6 传送数据
11.6.1 发送数据
11.6.2 接收数据
11.7 关闭套接口
11.8 本地进程间通信
l1.8.1 信号量
11.8.2 消息队列
11.8.3 共享内存
11.9 复习题一
11.10 参考文献.
第12章 网络通信
12.1 内部结构
12.1.l 数据流
12.1.2 通信协议
12.1.3 网络接口
12.2 套接口到协议的接口
12.2.1 协议的用户请求例程·
12.2.2 协议的控制输出例程·
12.3 协议到协议的接口
12.3.1 proutput
12.3.2 pr_input
12.3.3 pr-ctlinput
12.4 协议和网络的接口
12.4.1 发送数据包
12.4.2 接收数据包
12.5 路由选择
12.5.1 内核路由选择表
12.5.2 路由选择查找
12.5.3 路由选择重定向
12.5.4 路由选择表接口
12.5.5 用户级的路由选择策略
12.5.6 用户级路由选择接口:路由选择套接口·
12.6 缓冲和拥塞控制
12.6.1 协议缓冲策略·
12.6.2 队列限制
12.7 原始套接口
12.7.1 控制块--
12.7.2 输入处理
12.7.3 输出处理
12.8 网络子系统的其他主题
12.8.1 带外数据
12.8.2 地址解析协议
12.9 复习题
12.10 参考文献
第13章 网络协议
13.1 IPv4网络协议
13.1.1 IPv4地址
13.1.2 广播地址
13.1.3 组播
13.1.4 端口与关联
13.1.5 协议控制块
13.2 UDP协议
13.2.1 初始化
13.2.2 输出
13.2.3 输入
13.2.4 控制操作
13.3 Internet协议(IP)
13.3.1 输出
13.3.2 输入
13.3.3 转发
13.4 TCP协议
13.4.1 TCP连接状态
13.4.2 序号变量
13.5 TCP算法“
13.5.1 定时器
13.5.2 往返时间的估计
13.5.3 建立连接
13.5.4 SYN缓存
13.5.5 关闭连接
13.6 TCP输入处理
13.7 TCP输出处理
13.7.1 发送数据
13.7.2 避免糊涂窗口综合症
13.7.3 避免小数据包
13.7.4 确认延迟和窗口更新
13.7.5 重发状态
13.7.6 慢启动
13.7.7 源拥塞的处理
13.7.8 缓冲与窗口大小分配.
13.7.9 使用慢启动避免拥塞
13.7.10 快速重发·
13.8 ICMP协议
13.9 IPv6
13.9.1 IPv6地址..
13.9.2 IPv6数据包格式
13.9.3 套接口API的调整
13.9.4 自动配置
13.10 安全
13.10.1 IPSec概述
13.10.2 安全协议
13.10.3 密钥管理
13.10.4 IPSec实现
13.10.5 密码子系统
13.11复习题
13.12 参考文献
第五部分 系统运行
第14章 启动和关机
14.1 概述
14.2 引导
14.3 初始化内核
14.4 初始化内核模块
14.4.1 基本服务
14.4.2 初始化内核线程
14.4.3 初始化设备模块
14.4.4 内核的可加载模块
14.4.5 启动进程间通信
14.4.6 启动内核线程
14.5 用户级仞始化
14.5.1 /sbin/init
14.5.2 系统的启动脚本
14.5.3 /usr/libexec/getty
14.5.4 /usr/bin/lo~in
14.6 系统运行
14.6.1 内核的配置
14.6.2 系统关机与自动重启
14.6.3 系统调试
14.6.4 同内核传递信息
14.7 复习题
14.8 参考文献
术语表

本目录推荐