Mnesia
Mnesia,是使用Erlang程式語言编写的分布式、软实时数据库管理系统。它也是作为开放电信平台的一部分发布的。[2]
原作者 | 喬·阿姆斯特朗, 罗伯.威廉, 丹.古德门德松以及其他人 |
---|---|
開發者 | 爱立信 |
当前版本 |
|
编程语言 | Erlang |
操作系统 | 跨平台 |
平台 | 跨平台 |
类型 | 关系型 数据库管理系统 |
许可协议 | Erlang开源许可证 |
网站 | www |
描述
Mnesia 与 Erlang 都是爱立信公司为与电信相关的软实时分布式高可用的计算工作而开发的。它既不是为了通用办公型数据处理设计的数据库管理系统。也无意于替代基于 SQL 语言的系统。它是为了帮助 Erlang 实现数据管理系统类的数据持久化而存在的。[3]比起带有SQL的数据库服务器,它与像 Berkeley DB 这样的嵌入式数据库管理系统更相似。
数据库模型
表中的“行”代表了包含一个键值以及一个数据域的记录。这条数据域可能是一个包含任意复杂形式的 Erlang 数据结构的元组。
关系型特性
数据库模型是关系型的,但它并不是用大家比较熟悉的 SQL 操作的。一个数据库中的多个表可以在互相之间构建联系。[4]
Mnesia 高可用的一个关键特性就在于数据库中的表可以重新配置,并且可以在节点之间互相迁移。你不仅可以在数据库运行的时候这样操作,甚至还可以在数据库正在读写的时候操作。
编码
Mnesia 的查询语言不是 SQL 语言,而是 Erlang 本身。[5]这也意味着它可以让开发者直接使用 erlang 语言的特性来表达事务,开发者可以仅仅使用一个语言开发一个完整的应用程序。
事务
Erlang 是函数式编程语言。Mnesia 正是基于这一点来做到 ACID 事务的。作为事务运行的函数块仅仅只是一个非常普通的被称为函数对象的 Erlang 构造体。[6]写成单条 Mnesia 语句为 mnesia:transaction(F)
。 这样一来就可以使源代码变得要比 SQL 的 BEGIN
/ COMMIT
配对的语法更清晰,同时也避免了在过程中没有关闭事务的问题。
又因为 Erlang 的函数式特性,嵌套事务也非常简单。也可以在多个结点(也就是单独的服务器)里发布事务。以这种方式使用事务可以让语义保持一致,同时也让编写库代码在上下文保持一致的效果。
Mnesia 的一般编码风格是总是使用事务。考虑到性能问题,Mnesia 也支持用户使用“脏操作”来避免使用事务。这些操作虽然是对 ACID 原子性以及隔离性的妥协,但也提供了大概10倍的吞吐量。[7]除此以外,它还提供了将数据存储在内存中的选项,然而这么做会丢失 ACID 的持久性。
有效执行
Mnesia 是 LYME web 应用程序栈的一部分。这与 LAMP 类似,但它是基于 Erlang。用 Erlang实现会带来一个效率上的好处,那就是开发出来的应用程序自始至终是运行在单个虚拟机上的。LYME 充分利用了这一点,因为连 Yawsweb 服务器都是由 Erlang 实现的。
起源和许可
Mnesia 和 Erlang 都是爱立信计算机科学实验室开发的。他们都是作为开源软件发布的。Mnesia 是基于Mozilla公共许可证的衍生版发布的。[9]他们都是根据开源 Erlang 公共许可证发行的。[10]
参见
- Riak
- Apache Cassandra
- Couchbase
- CouchDB
- LYME (software bundle)
引用
- http://erlang.org/doc/apps/mnesia/notes.html#mnesia-4.16; 出版日期: 2019年5月13日.
- Håkan Mattsson; Hans Nilsson; Claes Wikstrom. (PDF). 1999 [2018-01-12]. (原始内容 (PDF)存档于2021-09-22).
- . Erlang开源项目. [2018-01-12]. (原始内容存档于2021-06-20).
- . Erlang 开源项目. [2018-01-12]. (原始内容存档于2021-06-20).
- . Erlang 开源项目. [2018-01-12]. (原始内容存档于2022-05-12).
- . Erlang 开源项目. [2018-01-12]. (原始内容存档于2010-06-13).
- Gavin Terrill. . InfoQ. 2007年8月20日 [2018年1月12日]. (原始内容存档于2022年4月26日).
- . [2018-01-12]. (原始内容存档于2012-12-02).
- . Erlang开源项目. [2018-01-12]. (原始内容存档于2020-02-22).
- . Erlang开源项目. [2018-01-12]. (原始内容存档于2021-11-05).
- . [2022-05-15]. (原始内容存档于2022-05-04).