Linux 中的 DBM 数据库使用指南
1. 死锁问题
在数据库应用中,当多个程序相互等待对方释放资源,导致都无法继续执行时,这种情况被称为死锁(deadlock),也叫致命拥抱(deadly embrace)。这是多用户频繁访问同一数据时常见的问题。多数商业关系型数据库能自动检测并解除死锁,但 Linux 内核不能。要解决死锁问题,可能需要外部干预,比如强制终止其中一个程序。
程序员在处理多个程序等待锁的情况时,必须格外小心,考虑是否会出现死锁。避免死锁的方法很简单,比如让所有程序按相同顺序锁定所需字节,或者使用更大的区域进行锁定。
2. 数据库的优势
相较于使用文件存储数据,数据库有一些明显的优势:
- 可变大小的数据记录 :使用平面、无结构的文件实现可变大小的数据记录存储可能有些困难,但数据库可以轻松处理。
- 高效的数据存储和检索 :数据库使用索引来存储和检索数据,而且这个索引可以是任意字符串,而不只是简单的记录编号,这在平面文件中实现起来相对容易。
3. DBM 数据库概述
所有 Linux 版本和大多数 UNIX 系统都自带了一套基本但高效的数据存储例程,即 DBM 数据库。DBM 数据库非常适合存储相对静态的索引数据。虽然有些数据库纯粹主义者认为 DBM 只是一个索引文件存储系统,但 X/Open 规范将其定义为数据库。
尽管像 MySQL 和 PostgreSQL 这样的免费关系型数据库不断发展,但 DBM 数据库在 Linux 中仍发挥着重要作用。例如,使用 RPM 的发行版(如
超级会员免费看
订阅专栏 解锁全文
89

被折叠的 条评论
为什么被折叠?



