Как работает сердце Эрланга? - PullRequest
1 голос
/ 29 июля 2011

Этот вопрос связан с моим предыдущим: Запуск оболочки erlang в качестве демона / службы

У меня есть скрипт, который выглядит так:

#!/bin/bash
# Load the VERBOSE setting and other rcS variables
. /lib/init/vars.sh
# Define LSB log_* functions.
# Depend on lsb-base (>= 3.0-6) to ensure that this file is present.
. /lib/lsb/init-functions


export HEART_COMMAND="/etc/init.d/script restart"

start() {


        erl  -heart -pa DIR -sname NAME -setcookie COOKIE -env port 21 -s M -s M2 --
        ### Create the lock file ###
        touch /var/lock/lock
}

stop() {

        erl -noshell -sname temp_control -setcookie COOKIE -eval "rpc:call(NAME@ubuntu, init, stop, [])" -s init stop
        ### Now, delete the lock file ###
        rm -f /var/lock/lock
}


### main logic ###
case "$1" in
  start)
        start
        ;;
  stop)
        stop
        ;;
  restart)
        stop
       # start
        ;;
  *)
        echo $"Usage: $0 {start|stop|restart}"
        exit 1
esac

exit 0

Я не знаю, как имитировать сбой, поэтому я просто попробовал ctrl + c и прервал оболочку, вывод выглядит так:

root@ubuntu:/etc/init.d# ./script start
heart_beat_kill_pid = 17512
Erlang R13B03 (erts-5.7.4) [source] [64-bit] [smp:4:4] [rq:4] [async-threads:0] [hipe] [kernel-poll:false]

Eshell V5.7.4  (abort with ^G)
(NAME@ubuntu)1> Starting M2
Listening on port 21

(NAME@ubuntu)1>
(NAME@ubuntu)1>
(NAME@ubuntu)1>
(NAME@ubuntu)1>
(NAME@ubuntu)1>
BREAK: (a)bort (c)ontinue (p)roc info (i)nfo (l)oaded
       (v)ersion (k)ill (D)b-tables (d)istribution
a
heart: Fri Jul 29 09:25:10 2011: Erlang has closed.
root@ubuntu:/etc/init.d# heart_beat_kill_pid = 17557
heart: Fri Jul 29 09:25:13 2011: Erlang has closed.
/etc/init.d/NAME: line 20: 17557 Killed                  erl  -heart -pa DIR -sname NAME -setcookie COOKIE -env port 21 -s M -s M2 --
heart: Fri Jul 29 09:25:13 2011: Executed "/etc/init.d/script restart". Terminating.
heart_beat_kill_pid = 17602
heart: Fri Jul 29 09:25:15 2011: Erlang has closed.
/etc/init.d/NAME: line 20: 17602 Killed                  erl  -heart -pa DIR -sname NAME -setcookie COOKIE -env port 21 -s M -s M2 --
heart: Fri Jul 29 09:25:15 2011: Executed "/etc/init.d/script restart". Terminating.
heart: Fri Jul 29 09:25:17 2011: Executed "/etc/init.d/script restart". Terminating.

root@ubuntu:/etc/init.d#

Это будет продолжаться вечно, если я не прокомментирую строку кода в скрипте, который его запускает. Это как бесконечный цикл завершающих оболочек эрланга ... или что-то подобное.

Если я попытаюсь, например, "export HEART_COMMAND =" / bin / echo hello ", то появится сообщение" ошибка записи: сломанный канал ".

Почему это не работает? Как правильно имитировать сбой, чтобы проверить, работает ли команда heart?

Благодарю за любой совет, который вы могли бы дать.

1 Ответ

2 голосов
/ 02 августа 2011

Отвечая на вопрос, который вы не задавали (но пару раз упоминали, что не знаете, как это сделать)

Чтобы смоделировать сбой, выполните следующие действия.

$ sleep 30 &
[1] 13274


$ kill -SEGV 13274
[1]+  Segmentation fault      sleep 30

Кроме того, пока я не знаю erlang, Я предполагаю , что он порождает несколько потоков, и один поток может отслеживать другой, отправляя сообщения пульса.Если другой поток не отвечает, предполагается, что он завис и перезапущен.

...