logo
分类于: 编程语言 计算机基础 互联网 云计算&大数据

简介

MySQL技术内幕:InnoDB存储引擎(第2版): 数据库技术丛书

MySQL技术内幕:InnoDB存储引擎(第2版): 数据库技术丛书 8.6分

资源最后更新于 2020-03-29 02:55:56

作者:姜承尧

出版社:出版社机械工业出版社

出版日期:2013-06

ISBN:9787111422068

文件格式: pdf

标签: 计算机 编程 IT 数据库 MySQL 数据库技术丛书 InnoDB

简介· · · · · ·

本书由国内资深MySQL专家亲自执笔,国内外多位数据库专家联袂推荐。作为国内唯一一本关于InnoDB的专著,本书的第1版广受好评,第2版不仅针对最新的MySQL 5.6对相关内容进行了全面的补充,还根据广大读者的反馈意见对第1版中存在的不足进行了完善,本书大约重写了50%的内容。本书从源代码的角度深度解析了InnoDB的体系结构、实现原理、工作机制,并给出了大量最佳实践,能帮助你系统而深入地掌握InnoDB,更重要的是,它能为你设计管理高性能、高可用的数据库系统提供绝佳的指导。本书一共10章,首先宏观地介绍了MySQL的体系结构和各种常见的存储引擎以及它们之间的比较;接着以InnoDB的内部实现为切入点,逐一详细讲解了InnoDB存储引擎内部的各个功能模块的实现原理,包括InnoDB存储引擎的体系结构、内存中的数据结构、基于InnoDB存储引擎的表和页的物理存储、索引与算法、文件、锁、事务、备份与恢复,以及InnoDB的性能调优等重要的知识;最后对InnoDB存储引擎源代码的编译和调试做了介绍,对大家阅读和理解InnoDB的源代码有重要的指导意义。本书适合所有希望构建和管理高性能、高可用性的MySQL数据库系统的开发者和DBA阅读。作者:姜承尧

想要: 点击会收藏到你的 我的收藏,可以在这里查看

已收: 表示已经收藏

Tips: 注册一个用户 可以通过用户中心得到电子书更新的通知哦

目录

  1. 推荐序
  2. 前言
  3. 为什么要写这本书
  4. 第1版与第2版的区别
  5. 读者对象
  6. 如何阅读本书
  7. 勘误和支持
  8. 致谢
  9. 第1章 MySQL体系结构和存储引擎
  10. 1.1 定义数据库和实例
  11. 1.2 MySQL体系结构
  12. 1.3 MySQL存储引擎
  13. 1.3.1 InnoDB存储引擎
  14. 1.3.2 MyISAM存储引擎
  15. 1.3.3 NDB存储引擎
  16. 1.3.4 Memory存储引擎
  17. 1.3.5 Archive存储引擎
  18. 1.3.6 Federated存储引擎
  19. 1.3.7 Maria存储引擎
  20. 1.3.8 其他存储引擎
  21. 1.4 各存储引擎之间的比较
  22. 1.5 连接MySQL
  23. 1.5.1 TCP/IP
  24. 1.5.2 命名管道和共享内存
  25. 1.5.3 UNIX域套接字
  26. 1.6 小结
  27. 第2章 InnoDB存储引擎
  28. 2.1 InnoDB存储引擎概述
  29. 2.2 InnoDB存储引擎的版本
  30. 2.3 InnoDB体系架构
  31. 2.3.1 后台线程
  32. 2.3.2 内存
  33. 2.4 Checkpoint技术
  34. 2.5 Master Thread工作方式
  35. 2.5.1 InnoDB 1.0.x版本之前的Master Thread
  36. 2.5.2 InnoDB1.2.x版本之前的Master Thread
  37. 2.5.3 InnoDB 1.2.x版本的Master Thread
  38. 2.6 InnoDB关键特性
  39. 2.6.1 插入缓冲
  40. 2.6.2 两次写
  41. 2.6.3 自适应哈希索引
  42. 2.6.4 异步IO
  43. 2.6.5 刷新邻接页
  44. 2.7 启动、关闭与恢复
  45. 2.8 小结
  46. 第3章 文件
  47. 3.1 参数文件
  48. 3.1.1 什么是参数
  49. 3.1.2 参数类型
  50. 3.2 日志文件
  51. 3.2.1 错误日志
  52. 3.2.2 慢查询日志
  53. 3.2.3 查询日志
  54. 3.2.4 二进制日志
  55. 3.3 套接字文件
  56. 3.4 pid文件
  57. 3.5 表结构定义文件
  58. 3.6 InnoDB存储引擎文件
  59. 3.6.1 表空间文件
  60. 3.6.2 重做日志文件
  61. 3.7 小结
  62. 第4章 表
  63. 4.1 索引组织表
  64. 4.2 InnoDB逻辑存储结构
  65. 4.2.1 表空间
  66. 4.2.2 段
  67. 4.2.3 区
  68. 4.2.4 页
  69. 4.2.5 行
  70. 4.3 InnoDB行记录格式
  71. 4.3.1 Compact行记录格式
  72. 4.3.2 Redundant行记录格式
  73. 4.3.3 行溢出数据
  74. 4.3.4 Compressed和Dynamic行记录格式
  75. 4.3.5 CHAR的行结构存储
  76. 4.4 InnoDB数据页结构
  77. 4.4.1 File Header
  78. 4.4.2 Page Header
  79. 4.4.3 Infimum和Supremum Record
  80. 4.4.4 User Record和Free Space
  81. 4.4.5 Page Directory
  82. 4.4.6 File Trailer
  83. 4.4.7 InnoDB数据页结构示例分析
  84. 4.5 Named File Formats机制
  85. 4.6 约束
  86. 4.6.1 数据完整性
  87. 4.6.2 约束的创建和查找
  88. 4.6.3 约束和索引的区别
  89. 4.6.4 对错误数据的约束
  90. 4.6.5 ENUM和SET约束
  91. 4.6.6 触发器与约束
  92. 4.6.7 外键约束
  93. 4.7 视图
  94. 4.7.1 视图的作用
  95. 4.7.2 物化视图
  96. 4.8 分区表
  97. 4.8.1 分区概述
  98. 4.8.2 分区类型
  99. 4.8.3 子分区
  100. 4.8.4 分区中的NULL值
  101. 4.8.5 分区和性能
  102. 4.8.6 在表和分区间交换数据
  103. 4.9 小结
  104. 第5章 索引与算法
  105. 5.1 InnoDB存储引擎索引概述
  106. 5.2 数据结构与算法
  107. 5.2.1 二分查找法
  108. 5.2.2 二叉查找树和平衡二叉树
  109. 5.3 B+树
  110. 5.3.1 B+树的插入操作
  111. 5.3.2 B+树的删除操作
  112. 5.4 B+树索引
  113. 5.4.1 聚集索引
  114. 5.4.2 辅助索引
  115. 5.4.3 B+树索引的分裂
  116. 5.4.4 B+树索引的管理
  117. 5.5 Cardinality值
  118. 5.5.1 什么是Cardinality
  119. 5.5.2 InnoDB存储引擎的Cardinality统计
  120. 5.6 B+树索引的使用
  121. 5.6.1 不同应用中B+树索引的使用
  122. 5.6.2 联合索引
  123. 5.6.3 覆盖索引
  124. 5.6.4 优化器选择不使用索引的情况
  125. 5.6.5 索引提示
  126. 5.6.6 Multi-Range Read优化
  127. 5.6.7 Index Condition Pushdown(ICP)优化
  128. 5.7 哈希算法
  129. 5.7.1 哈希表
  130. 5.7.2 InnoDB存储引擎中的哈希算法
  131. 5.7.3 自适应哈希索引
  132. 5.8 全文检索
  133. 5.8.1 概述
  134. 5.8.2 倒排索引
  135. 5.8.3 InnoDB全文检索
  136. 5.8.4 全文检索
  137. 5.9 小结
  138. 第6章 锁
  139. 6.1 什么是锁
  140. 6.2 lock与latch
  141. 6.3 InnoDB存储引擎中的锁
  142. 6.3.1 锁的类型
  143. 6.3.2 一致性非锁定读
  144. 6.3.3 一致性锁定读
  145. 6.3.4 自增长与锁
  146. 6.3.5 外键和锁
  147. 6.4 锁的算法
  148. 6.4.1 行锁的3种算法
  149. 6.4.2 解决Phantom Problem
  150. 6.5 锁问题
  151. 6.5.1 脏读
  152. 6.5.2 不可重复读
  153. 6.5.3 丢失更新
  154. 6.6 阻塞
  155. 6.7 死锁
  156. 6.7.1 死锁的概念
  157. 6.7.2 死锁概率
  158. 6.7.3 死锁的示例
  159. 6.8 锁升级
  160. 6.9 小结
  161. 第7章 事务
  162. 7.1 认识事务
  163. 7.1.1 概述
  164. 7.1.2 分类
  165. 7.2 事务的实现
  166. 7.2.1 redo
  167. 7.2.2 undo
  168. 7.2.3 purge
  169. 7.2.4 group commit
  170. 7.3 事务控制语句
  171. 7.4 隐式提交的SQL语句
  172. 7.5 对于事务操作的统计
  173. 7.6 事务的隔离级别
  174. 7.7 分布式事务
  175. 7.7.1 MySQL数据库分布式事务
  176. 7.7.2 内部XA事务
  177. 7.8 不好的事务习惯
  178. 7.8.1 在循环中提交
  179. 7.8.2 使用自动提交
  180. 7.8.3 使用自动回滚
  181. 7.9 长事务
  182. 7.10 小结
  183. 第8章 备份与恢复
  184. 8.1 备份与恢复概述
  185. 8.2 冷备
  186. 8.3 逻辑备份
  187. 8.3.1 mysqldump
  188. 8.3.2 SELECT…INTO OUTFILE
  189. 8.3.3 逻辑备份的恢复
  190. 8.3.4 LOAD DATA INFILE
  191. 8.3.5 mysqlimport
  192. 8.4 二进制日志备份与恢复
  193. 8.5 热备
  194. 8.5.1 ibbackup
  195. 8.5.2 XtraBackup
  196. 8.5.3 XtraBackup实现增量备份
  197. 8.6 快照备份
  198. 8.7 复制
  199. 8.7.1 复制的工作原理
  200. 8.7.2 快照+复制的备份架构
  201. 8.8 小结
  202. 第9章 性能调优
  203. 9.1 选择合适的CPU
  204. 9.2 内存的重要性
  205. 9.3 硬盘对数据库性能的影响
  206. 9.3.1 传统机械硬盘
  207. 9.3.2 固态硬盘
  208. 9.4 合理地设置RAID
  209. 9.4.1 RAID类型
  210. 9.4.2 RAID Write Back功能
  211. 9.4.3 RAID配置工具
  212. 9.5 操作系统的选择
  213. 9.6 不同的文件系统对数据库性能的影响
  214. 9.7 选择合适的基准测试工具
  215. 9.7.1 sysbench
  216. 9.7.2 mysql-tpcc
  217. 9.8 小结
  218. 第10章 InnoDB存储引擎源代码的编译和调试
  219. 10.1 获取InnoDB存储引擎源代码
  220. 10.2 InnoDB源代码结构
  221. 10.3 MySQL 5.1版本编译和调试InnoDB源代码
  222. 10.3.1 Windows下的调试
  223. 10.3.2 Linux下的调试
  224. 10.4 cmake方式编译和调试InnoDB存储引擎
  225. 10.5 小结