从另一个Erlang shell访问单个正在运行的mnesia节点以仅查看表中的数据的最佳做法是什么?
我尝试打开两个shell并将它们指向同一个mnesia目录位置,在文档中找到这个后我意识到这是一个非常糟糕的主意.
-mnesia目录.存储所有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>
Run Code Online (Sandbox Code Playgroud)
另一个终端:
$ 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>
Run Code Online (Sandbox Code Playgroud)
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>
Run Code Online (Sandbox Code Playgroud)
Enter
请注意,如果您要切换回现有的 shell 提示符,则必须按显示 shell 提示符。
归档时间: |
|
查看次数: |
915 次 |
最近记录: |