当Mnesia节点正在运行时,如何从另一个Erlang shell访问它?

6
什么是从另一个Erlang shell访问单个运行中的mnesia节点以仅查看表中数据的最佳实践?
我尝试打开两个shell并将它们指向相同的mnesia目录位置,但在文档中找到以下内容后意识到这是一个非常糟糕的想法。
-mnesia dir 目录。存储所有Mnesia数据的目录名称。该目录名称必须对于当前节点是唯一的。绝不能在任何情况下共享相同的Mnesia目录。结果是完全不可预测的。
1个回答

1

我认为最简单的方法是加入远程 shell。只需使用 -remsh Node 参数启动 erl 即可。

$ 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>

请注意,如果您要切换回现有的Shell提示符,请按Enter键以显示它。这一点需要记住。

从两个Erlang应用程序中访问正在运行的Mnesia数据库的最佳实践是什么?添加一个节点到Mnesia集群并通过该方式访问,似乎有点过度设计了吧? - Peter Holko
@Peter:如果它在同一个Erlang集群中,那么请使用rpc模块,或者当您想要通过套接字进行通信时,请使用lib_chan。 - Hynek -Pichi- Vychodil
1
我建议在远程 Shell 中使用“-hidden”标志,特别是在处理分布式网络时。例如:erl -sname bar -remsh 'foo@hynek-notebook' -hidden。 - Mazen Harake

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接