加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 综合聚焦 > 服务器 > 安全 > 正文

在运行时从另一个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提示符.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读