在运行时从另一个Erlang shell访问Mnesia节点
发布时间:2020-12-15 22:33:39 所属栏目:安全 来源:网络整理
导读:从另一个Erlang shell访问单个正在运行的mnesia节点以仅查看表中的数据的最佳做法是什么? 我尝试打开两个shell并将它们指向同一个mnesia目录位置,在文档中找到这个后我意识到这是一个非常糟糕的主意. -mnesia目录.存储所有Mnesia数据的目录的名称.目录的名
从另一个Erlang
shell访问单个正在运行的mnesia节点以仅查看表中的数据的最佳做法是什么?
我尝试打开两个shell并将它们指向同一个mnesia目录位置,在文档中找到这个后我意识到这是一个非常糟糕的主意. -mnesia目录.存储所有Mnesia数据的目录的名称.目录的名称对于当前节点必须是唯一的.在任何情况下,两个节点都可以共享同一个Mnesia目录.结果完全不可预测. 解决方法
我认为最简单的方法是加入远程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,[]} --> c Eshell V5.7.5 (abort with ^G) (foo@hynek-notebook)1> User switch command --> j 1 {shell,[]} --> c 1 (bar@hynek-notebook)1> 请注意,如果要切换回现有提示,则必须按Enter才能显示shell提示符. (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |