|
19 | 19 | -behaviour(application). |
20 | 20 |
|
21 | 21 | -export([start/0, boot/0, stop/0, |
22 | | - stop_and_halt/0, await_startup/0, status/0, is_running/0, |
| 22 | + stop_and_halt/0, await_startup/0, await_startup2/0, status/0, is_running/0, |
23 | 23 | is_running/1, environment/0, rotate_logs/1, force_event_refresh/1, |
24 | 24 | start_fhc/0]). |
25 | 25 | -export([start/2, stop/1]). |
@@ -436,7 +436,7 @@ stop() -> |
436 | 436 | undefined -> ok; |
437 | 437 | _ -> |
438 | 438 | rabbit_log:info("RabbitMQ hasn't finished starting yet. Waiting for startup to finish before stopping..."), |
439 | | - await_startup(true) |
| 439 | + wait_to_finish_booting() |
440 | 440 | end, |
441 | 441 | rabbit_log:info("RabbitMQ is asked to stop...~n", []), |
442 | 442 | Apps = ?APPS ++ rabbit_plugins:active(), |
@@ -619,6 +619,35 @@ await_startup(HaveSeenRabbitBoot) -> |
619 | 619 | await_startup(true) |
620 | 620 | end. |
621 | 621 |
|
| 622 | +await_startup2() -> |
| 623 | + case is_booting() of |
| 624 | + true -> wait_to_finish_booting(); |
| 625 | + false -> |
| 626 | + case is_running() of |
| 627 | + true -> ok; |
| 628 | + false -> wait_to_start_booting(), |
| 629 | + wait_to_finish_booting() |
| 630 | + end |
| 631 | + end. |
| 632 | + |
| 633 | +is_booting() -> |
| 634 | + whereis(rabbit_boot) /= undefined. |
| 635 | + |
| 636 | +wait_to_start_booting() -> |
| 637 | + case whereis(rabbit_boot) of |
| 638 | + undefined -> timer:sleep(100), |
| 639 | + wait_to_start_booting(); |
| 640 | + _ -> ok |
| 641 | + end. |
| 642 | + |
| 643 | +wait_to_finish_booting() -> |
| 644 | + case whereis(rabbit_boot) of |
| 645 | + undefined -> true = is_running(), |
| 646 | + ok; |
| 647 | + _ -> timer:sleep(100), |
| 648 | + wait_to_finish_booting() |
| 649 | + end. |
| 650 | + |
622 | 651 | status() -> |
623 | 652 | S1 = [{pid, list_to_integer(os:getpid())}, |
624 | 653 | %% The timeout value used is twice that of gen_server:call/2. |
|
0 commit comments