- 浏览: 982397 次
- 性别:
- 来自: 广州
最新评论
-
qingchuwudi:
有用,非常感谢!
erlang进程的优先级 -
zfjdiamond:
你好 这条命令 在那里输入??
你们有yum 我有LuaRocks -
simsunny22:
这个是在linux下运行的吧,在window下怎么运行escr ...
escript的高级特性 -
mozhenghua:
http://www.erlang.org/doc/apps/ ...
mnesia 分布协调的几个细节 -
fxltsbl:
A new record of 108000 HTTP req ...
Haproxy 1.4-dev2: barrier of 100k HTTP req/s crossed
原文地址: http://www.erlang.org/~hakan/
Mnesia upgrade policy (PA3)
===========================
This paper describes the upgrade policy of the Mnesia application.
It is divided into the following chapters:
o Architecture overview
o Compatibility
o Configuration management
o Compatibility requirements on other applications
o Upgrade scenarios
o Remaining issues
Architecture overview
---------------------
Mnesia is a distributed DataBase Management System (DBMS), appropriate
for telecommunications applications and other Erlang applications
which require continuous operation and exhibit soft real-time
properties. Mnesia is entirely implemented in in Erlang.
Meta data about the persistent tables is stored in a public ets table,
called mnesia_gvar. This ets table is accessed concurrently by several
kinds of processes:
* Static - on each node Mnesia has about 10 static
processes. Eg. monitor, controller, tm, locker, recover, dumper...
* Dynamic - there are several kinds of dynamic processes are created
for various purposes. Eg. tab_copier, perform_dump, backup_master ...
* Client processes created by Mnesia users. These invokes the Mnesia
API to perform operations such as table lookups, table updates,
table reconfigurations...
All these kinds of processes communicates with each other both locally
(on the same node) and remotely.
Mnesia may either be configured to use local disc or be to totally
disc less. All disc resident data is located under one directory and
is hosted by disk_log and dets.
The persistent tables may be backed up to external media. By default
backups are hosted by disk_log.
Compatibility
-------------
Each release of Mnesia has a unique version identifier. If Mnesia is
delivered to somebody outside the development team, the version
identifier is always changed, even if only one file differs from the
previous release of Mnesia. This means that the exact version of each
file in Mnesia can be determined from the version identifier of the
Mnesia application.
Mnesia does NOT utilize the concept of OTP "patches". The smallest
deliverable is currently the entire application. In future releases we
will probably deliver binaries, source code and different kinds of
documentation as separate packages.
Changes of the version identifier follows a certain pattern, depending
of how compatible the new release is with the previous dito. The
version identifier consists of 3 integer parts: Major.Minor.Harmless
(or just Major.Minor when Harmless is 0).
If a harmless detail has been changed, the "Harmless" part is
incremented. The change must not imply any incompatibility problems
for the user. An application upgrade script (.appup) could be
delivered in order to utilize code change in a running system, if
required.
If the change is more than a harmless detail (or if it is a harmless
change but has implied a substantial rewrite of the code), the "Minor"
part is incremented. The change must not imply any incompatibility
problems for the user. An application upgrade script (.appup) for code
change in a running system, is not always possible to deliver if the
change is complex. A full restart of Mnesia (and all applications
using Mnesia) may be required, potentially on all nodes
simultaneously.
All other kinds of changes implies the "Major" part to be incremented.
The change may imply that users of Mnesia needs to rewrite their code,
restart from backup or other inconveniences. Application upgrade
script (.appup) for code change in a running system is probably too
complex to write.
In any case it is a good idea to always read the release notes.
Configuration management
------------------------
Each major release constitutes an own development branch. Bugfixes,
new functionality etc. are normally performed in the latest major
development branch only. The last release of Mnesia is always the best
and customers are encouraged to upgrade to it.
Application upgrade scripts (.appup) are only written if they are
explicitly requested by a customer. Preparing the code for a
smoothless code change in a running system is very demanding and
restrains productive development. The code that handles the upgrade is
extremely hard to test, but it must be 100% correct. If it is not 100%
correct it is totally useless since the error may easily escalate to a
node restart or an inconsistent database.
It may however not always be possible to enforce a customer to accept
the latest release of incompatibility reasons. If a customer already
has a running system and encounters a serious bug in Mnesia, we may be
enforced to fix the bug in an old release. Such a bugfix is performed
in a separate bugfix branch (dedicated for this particular bugfix).
All source files in the release is labled with the version identifier
(e.g. "mnesia_3.4.1"). An application upgrade script (.appup) is
probably needed.
Compatibility requirements on other applications
------------------------------------------------
Mnesia is entirely implemented in Erlang and depends heavily on the
Erts, Kernel and StdLib applications.
Changes of storage format in dets and disk_log may cause these files
to be automatically upgraded to the new format, but only if Mnesia
allows them to perform the "repair". As an effect of such a format
upgrade it is likely that the Mnesia files cannot be read by older
releases, but it may be acceptable that old releases not are forward
compatible.
Mnesia stores its data as binaries. Changes of the external binary
format must also be backward compatible. Automatic conversion to
the new format is required.
Note, that Mnesia backups may be archived in years and that this
requires Erts and Kernel to be backward compatible with very old
binary formats and disk_log formats.
Upgrade scenarios
-----------------
There are a wide range of upgrade scenarios that needs to be analyzed
before they occur in reality. Here follows a few of them:
Backup format change.
In the abstract header of the backup there is a version tag that
identifies the format of the rest of the backup. Backups may be
archived for a long period of time and it is important that
old backups can be loaded into newer versions of the system.
The backup format is Mnesia's survival format.
Changes in the abstract backup format requires the backup version
tag to be incremented and code to be written to convert the old
format at backup load time. Minor change.
The concrete format is an open format handled by a callback module
and it is up to the callback module implementors to handle future
changes. The default callback module uses disk_log and Mnesia relies
heavily on disk_log's ability to automatically convert old disk_log
files into new dito if the concrete format has been changed.
Transaction log file format change.
In the abstract header of the transaction log there is a version tag
that identifies the format of the rest of the log. Changes in the
abstract transaction log format requires the transaction log version
tag to be incremented and code to be written to convert the old
format when the log is dumped at startup. Minor change.
The concrete format is hidden by disk_log and Mnesia relies on
disk_log's ability to automatically convert old disk_log files into
new dito if the concrete format has been changed.
If the abstract format change is severe or if disk_log cannot
handle old disk_log formats the entire Mnesia database has to
be backed up to external media and then installed as fallback.
It may in worst case be neccessary to implement a new backup
callback module that does not make use of disk_log. Major change.
Decision table log file format change.
In the abstract header of the decision table log file there is a
version tag that identifies the format of the rest of the
log. The concrete format is hidden by disk_log and severe changes
in the abstract or concrete formats are handled in the same way
as complex changes of the transaction log file format: back the
database up and re-install it as a fallback. Major change.
Minor changes in the abstract format can be handled by conversion
code run at startup. Minor change.
.DAT file format change.
.DAT files has no abstract version format identifier.
The concrete format is hidden by dets and Mnesia relies on
dets' ability to automatically convert old dets files into
new dito if the concrete format has been changed.
Changes in the abstract or incompatible changes in the concrete
format are are handled in the same way as complex changes in the
transaction log file format: back the database up and re-install
it as a fallback.
Core file format change.
The core file is a debugging aid and contains essential information
about the database. The core is automatically produced when Mnesia
encounters a fatal error or manually by the user for the purpose
of enclosing it into a trouble report. The core file consists of
list of tagged tuples stored as a large binary. Future changes of
the core format can easily be handled by adding a version tag
first in the list if neccessary.
Persistent schema format change.
The schema is implemented as an ordinary table with table names
as key and a list of table properties as single attribute.
Each table property is represented as a tagged tuple and adding
new properties will not break any code. Minor change.
Incompatible changes of the schema representation can be handled
in the same way as complex changes of the transaction log file
format: back the database up and re-install it as a fallback.
Major change.
If the change is severe and impacts the backup format then it should
not be performed at all.
Renaming schema table to mnesia_schema.
All internal (d)ets tables are prefixed with 'mnesia_' in order
to avoid name conflicts with other applications. The only
exception is the table named 'schema'.
Renaming 'schema' to 'mnesia_schema' is a major change, that
may breaks much customer code if it is not done very careful,
since the name of the table is a part of the Mnesia API.
The least intrusive change would be to leave the name 'schema'
as a part of the API, but internally use the name 'mnesia_schema'
and map all usages of 'schema' in all internal modules that accesses
the schema table. It is however questionable if the change is
worth the work effort.
Transient schema format change
The transient schema information is stored in a public ets table
named mnesia_gvar. Changes in the transient schema format affects
a lot of processes and it is not feasible to change it dynamically.
A restart on all db_nodes is required. Minor change.
Configuration parameter change. *** partly not supported ***
Many of the configuration parameters ought to be possible to
be changed dynamically in a running system:
access_module
backup_module
debug
dump_log_load_regulation
dump_log_time_threshold
dump_log_update_in_place
dump_log_write_threshold
event_module
extra_db_nodes
The remaining configuration parameters are only interesting at
startup and any dynamic change of these should silently be ignored:
auto_repair
dir
embedded_mnemosyne
ignore_fallback_at_startup
max_wait_for_decision
schema_location
Inter node protocol change. *** partly not supported ***
When Mnesia on one node tries to connect to Mnesia on another
node it negotiates with the other node about which inter node
communication protocol to use. A list of all known protocols
identifiers are sent to the other node which replies with the
protocol that it prefers. The other node may also reject the
connection. Always when the inter node protocol needs to be changed,
the protocol identifier is changed.
If the change is a compatible change and we need to upgrade the
protocol in a running system things gets a little bit complicated.
A new version of the software which understands both the old an new
protocols must be loaded on all nodes as a first step. All processes
that uses old code must somehow switch to use the new code. One
severe problem here is to locate all processes that needs a code
switch. Server processes are fairly straight forward to manage.
Client processes that are waiting in a receive statement are far
more difficult to first locate and then force a code switch.
We may prepare for the code switch by letting the client be
able to receive a special code switch message and then continue
to wait for interesting messages. (gen_server does not handle this
but since Mnesia does not use gen_server's for performance critical
processes or crash sensitive processes Mnesia can handle this in
many cases.)
If the new protocol is a pure extension of the old dito we may
go ahead and use the new protocol and bump up the protocol
version identifier.
More complex protocol changes are sometimes possible to handle,
but since they are extreamly hard to test it is probably better
to restart the system.
If the change is an incompatible change, Mnesia must be restarted on
all nodes.
Intra node protocol change.
Changing protocol between processes on the same node is slightly
easier than changing inter node protocols. The difference is that
we may iterate over all nodes and restart them one and one until
the software has started to use the new protocols on all nodes.
Adding a new static process.
Adding a new static process in Mnesia is a minor change,
but cannot be handled by the supervisor "application"
if the shutdown order of the static processes are important.
The most relieable approach here is to restart Mnesia.
Adopt to new functionality in Erts, Kernel or StdLib:
When was the new functionality introduced?
Can Mnesia use the new functionality and still
run on older Erlang/OTP releases?
Changing a function in the Mnesia API.
Changes of module name, function name, arguments or
semantics of a function is likely to be a major change.
Adding a brand new function is a minor change.
Changing a Mnesia internal function.
If it is possible to locate all processes that may
invoke the function it may be worth to handle the
code change in a running system. The safe approach
is to restart the node. The processes must be able
to handle 'sys' messages and export 'sys' callback
functions. Minor change.
Process state format change.
If it is possible to locate all processes that may
invoke the function it may be worth to handle the
code change in a running system. The safe approach
is to restart the node. The processes must be able
to handle 'sys' messages and export 'sys' callback
functions. Minor change.
Code change to fix a harmless bug.
Does these exist in reality or only in the Erlang book?
Code change to fix an inconsistency bug.
A bug like all others but the effect of it is an
inconsistent database. Mnesia cannot repair the database
and it is up to the Mnesia users to make it consistent
again. There are three options here:
- ignore the fact that the database is inconsistent
- back up the database and make the backup consistent
before installing it as a fallback.
- fix the inconsistency on-line while all applications
are accessing the database
Code change to prevent an indefinite wait (deadlock, protocol mismatch).
A bug like all others but the effect of it is hanging
processes. Restart Mnesia on one or more nodes.
Remaining issues
----------------
The following issues remains to be implemented:
- Dynamic configuration parameter change
- Prepare code switch of client code
Mnesia upgrade policy (PA3)
===========================
This paper describes the upgrade policy of the Mnesia application.
It is divided into the following chapters:
o Architecture overview
o Compatibility
o Configuration management
o Compatibility requirements on other applications
o Upgrade scenarios
o Remaining issues
Architecture overview
---------------------
Mnesia is a distributed DataBase Management System (DBMS), appropriate
for telecommunications applications and other Erlang applications
which require continuous operation and exhibit soft real-time
properties. Mnesia is entirely implemented in in Erlang.
Meta data about the persistent tables is stored in a public ets table,
called mnesia_gvar. This ets table is accessed concurrently by several
kinds of processes:
* Static - on each node Mnesia has about 10 static
processes. Eg. monitor, controller, tm, locker, recover, dumper...
* Dynamic - there are several kinds of dynamic processes are created
for various purposes. Eg. tab_copier, perform_dump, backup_master ...
* Client processes created by Mnesia users. These invokes the Mnesia
API to perform operations such as table lookups, table updates,
table reconfigurations...
All these kinds of processes communicates with each other both locally
(on the same node) and remotely.
Mnesia may either be configured to use local disc or be to totally
disc less. All disc resident data is located under one directory and
is hosted by disk_log and dets.
The persistent tables may be backed up to external media. By default
backups are hosted by disk_log.
Compatibility
-------------
Each release of Mnesia has a unique version identifier. If Mnesia is
delivered to somebody outside the development team, the version
identifier is always changed, even if only one file differs from the
previous release of Mnesia. This means that the exact version of each
file in Mnesia can be determined from the version identifier of the
Mnesia application.
Mnesia does NOT utilize the concept of OTP "patches". The smallest
deliverable is currently the entire application. In future releases we
will probably deliver binaries, source code and different kinds of
documentation as separate packages.
Changes of the version identifier follows a certain pattern, depending
of how compatible the new release is with the previous dito. The
version identifier consists of 3 integer parts: Major.Minor.Harmless
(or just Major.Minor when Harmless is 0).
If a harmless detail has been changed, the "Harmless" part is
incremented. The change must not imply any incompatibility problems
for the user. An application upgrade script (.appup) could be
delivered in order to utilize code change in a running system, if
required.
If the change is more than a harmless detail (or if it is a harmless
change but has implied a substantial rewrite of the code), the "Minor"
part is incremented. The change must not imply any incompatibility
problems for the user. An application upgrade script (.appup) for code
change in a running system, is not always possible to deliver if the
change is complex. A full restart of Mnesia (and all applications
using Mnesia) may be required, potentially on all nodes
simultaneously.
All other kinds of changes implies the "Major" part to be incremented.
The change may imply that users of Mnesia needs to rewrite their code,
restart from backup or other inconveniences. Application upgrade
script (.appup) for code change in a running system is probably too
complex to write.
In any case it is a good idea to always read the release notes.
Configuration management
------------------------
Each major release constitutes an own development branch. Bugfixes,
new functionality etc. are normally performed in the latest major
development branch only. The last release of Mnesia is always the best
and customers are encouraged to upgrade to it.
Application upgrade scripts (.appup) are only written if they are
explicitly requested by a customer. Preparing the code for a
smoothless code change in a running system is very demanding and
restrains productive development. The code that handles the upgrade is
extremely hard to test, but it must be 100% correct. If it is not 100%
correct it is totally useless since the error may easily escalate to a
node restart or an inconsistent database.
It may however not always be possible to enforce a customer to accept
the latest release of incompatibility reasons. If a customer already
has a running system and encounters a serious bug in Mnesia, we may be
enforced to fix the bug in an old release. Such a bugfix is performed
in a separate bugfix branch (dedicated for this particular bugfix).
All source files in the release is labled with the version identifier
(e.g. "mnesia_3.4.1"). An application upgrade script (.appup) is
probably needed.
Compatibility requirements on other applications
------------------------------------------------
Mnesia is entirely implemented in Erlang and depends heavily on the
Erts, Kernel and StdLib applications.
Changes of storage format in dets and disk_log may cause these files
to be automatically upgraded to the new format, but only if Mnesia
allows them to perform the "repair". As an effect of such a format
upgrade it is likely that the Mnesia files cannot be read by older
releases, but it may be acceptable that old releases not are forward
compatible.
Mnesia stores its data as binaries. Changes of the external binary
format must also be backward compatible. Automatic conversion to
the new format is required.
Note, that Mnesia backups may be archived in years and that this
requires Erts and Kernel to be backward compatible with very old
binary formats and disk_log formats.
Upgrade scenarios
-----------------
There are a wide range of upgrade scenarios that needs to be analyzed
before they occur in reality. Here follows a few of them:
Backup format change.
In the abstract header of the backup there is a version tag that
identifies the format of the rest of the backup. Backups may be
archived for a long period of time and it is important that
old backups can be loaded into newer versions of the system.
The backup format is Mnesia's survival format.
Changes in the abstract backup format requires the backup version
tag to be incremented and code to be written to convert the old
format at backup load time. Minor change.
The concrete format is an open format handled by a callback module
and it is up to the callback module implementors to handle future
changes. The default callback module uses disk_log and Mnesia relies
heavily on disk_log's ability to automatically convert old disk_log
files into new dito if the concrete format has been changed.
Transaction log file format change.
In the abstract header of the transaction log there is a version tag
that identifies the format of the rest of the log. Changes in the
abstract transaction log format requires the transaction log version
tag to be incremented and code to be written to convert the old
format when the log is dumped at startup. Minor change.
The concrete format is hidden by disk_log and Mnesia relies on
disk_log's ability to automatically convert old disk_log files into
new dito if the concrete format has been changed.
If the abstract format change is severe or if disk_log cannot
handle old disk_log formats the entire Mnesia database has to
be backed up to external media and then installed as fallback.
It may in worst case be neccessary to implement a new backup
callback module that does not make use of disk_log. Major change.
Decision table log file format change.
In the abstract header of the decision table log file there is a
version tag that identifies the format of the rest of the
log. The concrete format is hidden by disk_log and severe changes
in the abstract or concrete formats are handled in the same way
as complex changes of the transaction log file format: back the
database up and re-install it as a fallback. Major change.
Minor changes in the abstract format can be handled by conversion
code run at startup. Minor change.
.DAT file format change.
.DAT files has no abstract version format identifier.
The concrete format is hidden by dets and Mnesia relies on
dets' ability to automatically convert old dets files into
new dito if the concrete format has been changed.
Changes in the abstract or incompatible changes in the concrete
format are are handled in the same way as complex changes in the
transaction log file format: back the database up and re-install
it as a fallback.
Core file format change.
The core file is a debugging aid and contains essential information
about the database. The core is automatically produced when Mnesia
encounters a fatal error or manually by the user for the purpose
of enclosing it into a trouble report. The core file consists of
list of tagged tuples stored as a large binary. Future changes of
the core format can easily be handled by adding a version tag
first in the list if neccessary.
Persistent schema format change.
The schema is implemented as an ordinary table with table names
as key and a list of table properties as single attribute.
Each table property is represented as a tagged tuple and adding
new properties will not break any code. Minor change.
Incompatible changes of the schema representation can be handled
in the same way as complex changes of the transaction log file
format: back the database up and re-install it as a fallback.
Major change.
If the change is severe and impacts the backup format then it should
not be performed at all.
Renaming schema table to mnesia_schema.
All internal (d)ets tables are prefixed with 'mnesia_' in order
to avoid name conflicts with other applications. The only
exception is the table named 'schema'.
Renaming 'schema' to 'mnesia_schema' is a major change, that
may breaks much customer code if it is not done very careful,
since the name of the table is a part of the Mnesia API.
The least intrusive change would be to leave the name 'schema'
as a part of the API, but internally use the name 'mnesia_schema'
and map all usages of 'schema' in all internal modules that accesses
the schema table. It is however questionable if the change is
worth the work effort.
Transient schema format change
The transient schema information is stored in a public ets table
named mnesia_gvar. Changes in the transient schema format affects
a lot of processes and it is not feasible to change it dynamically.
A restart on all db_nodes is required. Minor change.
Configuration parameter change. *** partly not supported ***
Many of the configuration parameters ought to be possible to
be changed dynamically in a running system:
access_module
backup_module
debug
dump_log_load_regulation
dump_log_time_threshold
dump_log_update_in_place
dump_log_write_threshold
event_module
extra_db_nodes
The remaining configuration parameters are only interesting at
startup and any dynamic change of these should silently be ignored:
auto_repair
dir
embedded_mnemosyne
ignore_fallback_at_startup
max_wait_for_decision
schema_location
Inter node protocol change. *** partly not supported ***
When Mnesia on one node tries to connect to Mnesia on another
node it negotiates with the other node about which inter node
communication protocol to use. A list of all known protocols
identifiers are sent to the other node which replies with the
protocol that it prefers. The other node may also reject the
connection. Always when the inter node protocol needs to be changed,
the protocol identifier is changed.
If the change is a compatible change and we need to upgrade the
protocol in a running system things gets a little bit complicated.
A new version of the software which understands both the old an new
protocols must be loaded on all nodes as a first step. All processes
that uses old code must somehow switch to use the new code. One
severe problem here is to locate all processes that needs a code
switch. Server processes are fairly straight forward to manage.
Client processes that are waiting in a receive statement are far
more difficult to first locate and then force a code switch.
We may prepare for the code switch by letting the client be
able to receive a special code switch message and then continue
to wait for interesting messages. (gen_server does not handle this
but since Mnesia does not use gen_server's for performance critical
processes or crash sensitive processes Mnesia can handle this in
many cases.)
If the new protocol is a pure extension of the old dito we may
go ahead and use the new protocol and bump up the protocol
version identifier.
More complex protocol changes are sometimes possible to handle,
but since they are extreamly hard to test it is probably better
to restart the system.
If the change is an incompatible change, Mnesia must be restarted on
all nodes.
Intra node protocol change.
Changing protocol between processes on the same node is slightly
easier than changing inter node protocols. The difference is that
we may iterate over all nodes and restart them one and one until
the software has started to use the new protocols on all nodes.
Adding a new static process.
Adding a new static process in Mnesia is a minor change,
but cannot be handled by the supervisor "application"
if the shutdown order of the static processes are important.
The most relieable approach here is to restart Mnesia.
Adopt to new functionality in Erts, Kernel or StdLib:
When was the new functionality introduced?
Can Mnesia use the new functionality and still
run on older Erlang/OTP releases?
Changing a function in the Mnesia API.
Changes of module name, function name, arguments or
semantics of a function is likely to be a major change.
Adding a brand new function is a minor change.
Changing a Mnesia internal function.
If it is possible to locate all processes that may
invoke the function it may be worth to handle the
code change in a running system. The safe approach
is to restart the node. The processes must be able
to handle 'sys' messages and export 'sys' callback
functions. Minor change.
Process state format change.
If it is possible to locate all processes that may
invoke the function it may be worth to handle the
code change in a running system. The safe approach
is to restart the node. The processes must be able
to handle 'sys' messages and export 'sys' callback
functions. Minor change.
Code change to fix a harmless bug.
Does these exist in reality or only in the Erlang book?
Code change to fix an inconsistency bug.
A bug like all others but the effect of it is an
inconsistent database. Mnesia cannot repair the database
and it is up to the Mnesia users to make it consistent
again. There are three options here:
- ignore the fact that the database is inconsistent
- back up the database and make the backup consistent
before installing it as a fallback.
- fix the inconsistency on-line while all applications
are accessing the database
Code change to prevent an indefinite wait (deadlock, protocol mismatch).
A bug like all others but the effect of it is hanging
processes. Restart Mnesia on one or more nodes.
Remaining issues
----------------
The following issues remains to be implemented:
- Dynamic configuration parameter change
- Prepare code switch of client code
发表评论
-
OTP R14A今天发布了
2010-06-17 14:36 2677以下是这次发布的亮点,没有太大的性能改进, 主要是修理了很多B ... -
R14A实现了EEP31,添加了binary模块
2010-05-21 15:15 3030Erlang的binary数据结构非常强大,而且偏向底层,在作 ... -
如何查看节点的可用句柄数目和已用句柄数
2010-04-08 03:31 4814很多同学在使用erlang的过程中, 碰到了很奇怪的问题, 后 ... -
获取Erlang系统信息的代码片段
2010-04-06 21:49 3475从lib/megaco/src/tcp/megaco_tcp_ ... -
iolist跟list有什么区别?
2010-04-06 20:30 6529看到erlang-china.org上有个 ... -
erlang:send_after和erlang:start_timer的使用解释
2010-04-06 18:31 8386前段时间arksea 同学提出这个问题, 因为文档里面写的很不 ... -
Latest news from the Erlang/OTP team at Ericsson 2010
2010-04-05 19:23 2013参考Talk http://www.erlang-factor ... -
对try 异常 运行的疑问,为什么出现两种结果
2010-04-05 19:22 2842郎咸武<langxianzhe@163.com> ... -
Erlang ERTS Async基础设施
2010-03-19 00:03 2517其实Erts的Async做的很不错的, 相当的完备, 性能又高 ... -
CloudI 0.0.9 Released, A Cloud as an Interface
2010-03-09 22:32 2476基于Erlang的云平台 看了下代码 质量还是不错的 完成了不 ... -
Memory matters - even in Erlang (再次说明了了解内存如何工作的必要性)
2010-03-09 20:26 3439原文地址:http://www.lshift.net/blog ... -
Some simple examples of using Erlang’s XPath implementation
2010-03-08 23:30 2050原文地址 http://www.lshift.net/blog ... -
lcnt 环境搭建
2010-02-26 16:19 2614抄书:otp_doc_html_R13B04/lib/tool ... -
Erlang强大的代码重构工具 tidier
2010-02-25 16:22 2486Jan 29, 2010 We are very happy ... -
[Feb 24 2010] Erlang/OTP R13B04 has been released
2010-02-25 00:31 1387Erlang/OTP R13B04 has been rele ... -
R13B04 Installation
2010-01-28 10:28 1390R13B04后erlang的源码编译为了考虑移植性,就改变了编 ... -
Running tests
2010-01-19 14:51 1486R13B03以后 OTP的模块加入了大量的测试模块,这些模块都 ... -
R13B04在细化Binary heap
2010-01-14 15:11 1508从github otp的更新日志可以清楚的看到otp R13B ... -
R13B03 binary vheap有助减少binary内存压力
2009-11-29 16:07 1668R13B03 binary vheap有助减少binary内存 ... -
erl_nif 扩展erlang的另外一种方法
2009-11-26 01:02 3218我们知道扩展erl有2种方法, driver和port. 这2 ...
相关推荐
session, specify a Mnesia database directory, initialize a database schema, start Mnesia, and create tables. Initial prototyping of record definitions is also discussed. • Build a Mnesia Database ...
B站视频地址: 做了文字校验,已经成功上线,有兴趣的小伙伴可以扫码体验:可以微信搜索:失忆备忘录一、失忆的由来之所以开发这款软件,是因为在那段时间事情很多,但是经常忘记。虽然市面上类似的功能很多,我之前...
AMNESIA是一个基于Erlang编程语言的开源库,专门设计用于简化与关系数据库管理系统(RDBMS)的交互。Erlang以其并发处理、容错性和高效性能在分布式系统领域备受推崇,而AMNESIA则进一步扩展了Erlang的功能,使...
Api-Social-Amnesia.zip,忘记过去。社交健忘症确保你的社交媒体帐户只显示你最近的历史,而不是5年前“那个阶段”的帖子。,一个api可以被认为是多个软件设备之间通信的指导手册。例如,api可用于web应用程序之间的...
语言:English (United States) 遗忘的延伸 Chrome失忆症是一个Chrome扩展程序,可让您有选择地不记得自己的任何浏览历史记录。...有关更多信息,请访问https://github.com/DanielBok/chrome-amnesia。
失忆症是一种提醒,允许您定义警报,贴纸(贴子)以提醒您一些重要的内容以及有关所需内容的注释。 可以将警报编程为在给定时间显示,可以在桌面上放置贴纸以随时查看。
3. 表模式:Mnesia支持多种表类型,如简单记录(flat files)、行链接表(linked-in disk tables)和内存表(RAM tables)。这些不同的表类型可以根据性能和持久性需求进行选择。 4. 查询语言:Mnesia提供了一个...
"Amnesia"是一个可能与计算机安全或数据丢失相关的主题,暗示了系统或用户可能遭遇了某种形式的记忆丧失,即数据无法访问或丢失的情况。在IT领域,这种情况通常涉及到磁盘故障、病毒攻击、误操作或者软件错误。"Post...
3、构建.Mnesia.数据库 3.1.定义模式 3.2.数据模型 3.3.启动.Mnesia 3.4.创建新表 4、事务和其他上下文存取 4.1.事务属性 4.2.锁 4.3.脏操作 4.4.记录名与表 4.5.作业(Activity)概念和多种存取上...
"Amnesia_CCK"是一个基于开源系统开发的项目,它主要关注的是"失忆症"游戏的源代码,经过特定的调整和优化,以便在CCK(Content Creation Kit)平台上进行展示。CCK通常是一个工具集,允许用户创建、修改和扩展游戏...
3. **紧密集成Erlang**:Mnesia与Erlang编程语言紧密集成,允许开发者使用Erlang函数直接操作数据库,从而简化了开发流程并提高了效率。 4. **事务处理**:Mnesia支持原子性、一致性、隔离性和持久性(ACID)事务,...
8 附录 A : Mnesia 错误信息 . . .. . . 75 8.1 Mnesia 中的错误 . . . . .. . 75 9 附录 B :备份回调函数接口 . . .. . .. . . .. . 76 9.1 Mnesia 备份回调行为 . . .. . . . .. . 76 10 附录 C :作业存取...
Mnesia 是一个分布式数据库管理系统,它是 Erlang 语言环境的一部分,专门设计用于在分布式系统中存储和查询数据。随着业务需求的增长,单个 Mnesia 表的大小和性能可能会成为瓶颈。为了解决这个问题,Mnesia 提供了...
3. **构建 Mnesia 数据库** - **定义模式**:模式定义了数据的结构,类似于数据库中的表结构。在Mnesia中,模式是Erlang的数据类型,如记录或原子值。 - **数据模型**:Mnesia 支持两种主要的数据模型:*正交表...