显然,我有一个在Erlang shell中运行的Erlang程序,我想监视它。
这就是我想要的:
示例:
/etc/init.d/foobar start
/etc/init.d/foobar stop
/etc/init.d/foobar restart
我还没有开始整个“重启自己,如果崩溃”的事情,被困在简单的事情,还是很容易?
我所做的是:
从/etc/init.d/skeleton获取骨架代码并替换了PATH,DESC,NAME等等......这样可行,我可以这样做:
/etc/init.d/foobar start
但是,我无法阻止它...问题是我用“erl”启动Erlang shell,这是一个做一些我不理解的奇特事情的脚本。它做的一件事是,它创建了一个非常漫长而复杂的流程名称。它不仅仅是“erl”,它就像:
/usr/lib/erlang/erts-5.7.4/bin/beam.smp - -root / usr / lib / erlang -progname erl - -home / home / xxx - ....和一些更多。
有更好的方法吗?
操作系统:Ubuntu 11.04
答案 0 :(得分:3)
您要做的是创建目标系统。这样做的文档在这里:http://www.erlang.org/doc/system_principles/create_target.html 但是,在你掌握基本概念之前,它起初有点复杂。
粗略地说,您执行以下操作:
然后可以将其作为具有重启/监视器的服务以及您要添加的任何内容进行管理。
答案 1 :(得分:2)
除了创建目标版本(@Martin推荐的标准Erlang生产环境)之外,还需要以下内容:
要允许自动重启崩溃的节点,您应该使用the heart functionality。
要停止正在运行的Erlang节点,您可以启动一个临时的Erlang节点,连接到正在运行的节点并发出一个停止命令:
erl -noshell -sname temp_control \
-eval "rpc:call(mynode@myhost, init, stop, [])" \
-s init stop
noshell
禁用输入和shell输出sname
设置临时节点的名称eval
让你执行任何有效的Erlang表达式
rpc:call(Node, M, F, A)
将在指定的节点上调用M:F(A)
(A
是将作为真实参数传递给函数的参数列表)s M F
运行函数M:F()
(eval
和s
按顺序运行)
答案 2 :(得分:2)
最近发布的erld项目是真正实现Erlang应用程序守护程序的绝佳方式。它为守护进程应该做的所有事情提供支持,即:
请在此处查看他们的github页面:https://github.com/ShoreTel-Inc/erld