erlang - 在运行时从另一个 Erlang shell 访问 Mnesia 节点

标签 erlang mnesia

从另一个 Erlang shell 访问单个运行的 mnesia 节点以仅查看表中的数据的最佳实践是什么?

我尝试打开两个 shell 并将它们指向同一个 mnesia 目录位置,在文档中找到这个后我意识到这是一个非常糟糕的主意。

-mnesia dir 目录。存储所有 Mnesia 数据的目录的名称。目录的名称对于当前节点必须是唯一的。在任何情况下,两个节点都不能共享同一个 Mnesia 目录。结果是完全不可预测的。

最佳答案

我认为最简单的方法是加入远程 shell。刚开始erl-remsh Node范围

$ erl -sname foo
Erlang R13B04 (erts-5.7.5) [source] [smp:2:2] [rq:2] [async-threads:0] [hipe] [kernel-poll:false]

Eshell V5.7.5  (abort with ^G)
(foo@hynek-notebook)1> 

另一个终端:
$ erl -sname bar -remsh 'foo@hynek-notebook'
Erlang R13B04 (erts-5.7.5) [source] [smp:2:2] [rq:2] [async-threads:0] [hipe] [kernel-poll:false]

Eshell V5.7.5  (abort with ^G)
(foo@hynek-notebook)1> 

另一种选择是使用 erl 强大的作业控制功能。 (按 ^G)
$ erl -sname bar
Erlang R13B04 (erts-5.7.5) [source] [smp:2:2] [rq:2] [async-threads:0] [hipe] [kernel-poll:false]

Eshell V5.7.5  (abort with ^G)
(bar@hynek-notebook)1> 
User switch command
 --> h
  c [nn]            - connect to job
  i [nn]            - interrupt job
  k [nn]            - kill job
  j                 - list all jobs
  s [shell]         - start local shell
  r [node [shell]]  - start remote shell
  q        - quit erlang
  ? | h             - this message
 --> r 'foo@hynek-notebook'
 --> j
   1  {shell,start,[init]}
   2* {'foo@hynek-notebook',shell,start,[]}
 --> c 
Eshell V5.7.5  (abort with ^G)
(foo@hynek-notebook)1> 
User switch command
 --> j
   1  {shell,start,[init]}
   2* {'foo@hynek-notebook',shell,start,[]}
 --> c 1

(bar@hynek-notebook)1>

请注意,您必须按 Enter如果您要切换回现有的,则显示 shell 提示。

关于erlang - 在运行时从另一个 Erlang shell 访问 Mnesia 节点,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/3122887/

相关文章:

database - 如何在 Erlang 中更新 Mnesia 表

erlang - Erl 中的记录(Erlang 问题)

erlang - 如何将元组内容与 qlc 和 mnesia 匹配?

javascript - 将 CouchDB javascript View 转换为 erlang

erlang - 有没有类似 erlang 的 gem 之类的东西?

apache-flex - Adobe Flex 到 erlang 连接?

Erlang ssh 模块无法识别我的 ssh key

erlang - 如何在 Erlang 中使用变量作为引用传递?

erlang - mnesia delete_object 异常?

database - 二郎 : Mnesia : Lookup and update based on fields other than the key