edeliver v1.2.7 Edeliver.Relup.Instructions.RerunFailedRequests
Runs phoenix requests again which failed during hot code upgrade.
This upgrade instruction notifies request processes
which were handling requests while new code was loaded
that they can be rerun if they failed during the upgrade.
It is required that a phoenix version is used
which supports the upgrade notification feature.
This instruction should be used in conjunction with and
after the
Edeliver.Relup.Instructions.FinishRunningRequests
instruction which notifies the request processes that the code upgrade is started.
To make sure that the http request connections can be found on the node, use this instruction after the
Edeliver.Relup.Instructions.CheckRanchConnections
instruction which will abort the upgrade if the http request connections accepted by ranch cannot be found in the supervision tree.
Summary
Functions
Returns name of the application. This name is taken as argument
for the run/1 function and is required to access the acceptor processes
through the supervision tree
Calls the run/1 function of this module
Logs a debug message using the Logger on the running node which is upgraded
This module depends on the Edeliver.Relup.Instructions.CheckRanchAcceptors,
the Edeliver.Relup.Instructions.CheckRanchConnections and the
Edeliver.Relup.Instructions.FinishRunningRequests module which must be loaded
before this instruction for upgrades and unload after this instruction for downgrades
Ensures that all Edeliver.Relup.RunnableInstruction modules used / referenced by this instruction
and returned by the dependencies/0 callback are loaded before this instruction is executed
during the upgrade
Ensures that all Edeliver.Relup.RunnableInstruction modules used / referenced by this instruction
and returned by the dependencies/0 callback are unloaded after this instruction is executed
during the downgrade
Logs an error using the Logger on the running node which is upgraded
Formats and prints the message on the node
Logs an info message using the Logger on the running node which is upgraded
Callback implementation for Edeliver.Relup.RunnableInstruction.insert_where/0
Logs the message of the given type on the node
Callback implementation for Edeliver.Relup.Instruction.modify_relup/2
Notifies request processes which handled http requests during the release upgrade / downgrade that the code loading is finished and that requests that failed during the code loading can be now rerun with the updated code
Logs a warning using the Logger on the running node which is upgraded
Macros
Assumes that the pattern matches or throws an error with the given error message
Types
insert_fun :: (%Edeliver.Relup.Instructions{changed_modules: term, down_instructions: term, down_version: term, up_instructions: term, up_version: term} | instructions, new_instructions :: instruction | instructions -> updated_instructions :: %Edeliver.Relup.Instructions{changed_modules: term, down_instructions: term, down_version: term, up_instructions: term, up_version: term} | instructions)
instruction :: :relup.instruction
instructions :: [instruction]
Functions
Specs
arguments(%Edeliver.Relup.Instructions{changed_modules: term, down_instructions: term, down_version: term, up_instructions: term, up_version: term}, %ReleaseManager.Config{dev: term, env: term, erl: term, name: term, package: term, relx_config: term, upgrade?: term, verbosity: term, version: term}) :: term
Returns name of the application. This name is taken as argument
for the run/1 function and is required to access the acceptor processes
through the supervision tree
Specs
call_this(arguments :: [term]) ::
instruction |
instructions
Calls the run/1 function of this module
from the relup file during hot code upgrade
Specs
debug(message :: String.t) :: no_return
Logs a debug message using the Logger on the running node which is upgraded.
In addition the same debug message is logged on the node which executes
the upgrade and is displayed as output of the
$APP/bin/$APP upgarde $RELEASE command.
Specs
dependencies :: [instruction_module :: atom]
dependencies :: [Edeliver.Relup.Instructions.CheckRanchAcceptors]
This module depends on the Edeliver.Relup.Instructions.CheckRanchAcceptors,
the Edeliver.Relup.Instructions.CheckRanchConnections and the
Edeliver.Relup.Instructions.FinishRunningRequests module which must be loaded
before this instruction for upgrades and unload after this instruction for downgrades.
Specs
ensure_dependencies_loaded_before_instruction_for_upgrade(instructions :: %Edeliver.Relup.Instructions{changed_modules: term, down_instructions: term, down_version: term, up_instructions: term, up_version: term}, runnable_instruction :: {:apply, {module :: atom, :run, arguments :: [term]}}, dependencies :: [instruction_module :: atom]) :: %Edeliver.Relup.Instructions{changed_modules: term, down_instructions: term, down_version: term, up_instructions: term, up_version: term}
Ensures that all Edeliver.Relup.RunnableInstruction modules used / referenced by this instruction
and returned by the dependencies/0 callback are loaded before this instruction is executed
during the upgrade.
Specs
ensure_dependencies_unloaded_after_instruction_for_downgrade(instructions :: %Edeliver.Relup.Instructions{changed_modules: term, down_instructions: term, down_version: term, up_instructions: term, up_version: term}, runnable_instruction :: {:apply, {module :: atom, :run, arguments :: [term]}}, dependencies :: [instruction_module :: atom]) :: %Edeliver.Relup.Instructions{changed_modules: term, down_instructions: term, down_version: term, up_instructions: term, up_version: term}
Ensures that all Edeliver.Relup.RunnableInstruction modules used / referenced by this instruction
and returned by the dependencies/0 callback are unloaded after this instruction is executed
during the downgrade.
Specs
error(message :: String.t) :: no_return
Logs an error using the Logger on the running node which is upgraded.
In addition the same error message is logged on the node which executes
the upgrade and is displayed as output of the
$APP/bin/$APP upgarde $RELEASE command.
Specs
format_in_upgrade_script(format :: char_list, arguments :: [term]) :: no_return
Formats and prints the message on the node
running the upgrade script which was started by the
$APP/bin/$APP upgrade $RELEASE command.
Specs
info(message :: String.t) :: no_return
Logs an info message using the Logger on the running node which is upgraded.
In addition the same info message is logged on the node which executes
the upgrade and is displayed as output of the
$APP/bin/$APP upgarde $RELEASE command.
Specs
insert_where :: insert_fun
Callback implementation for Edeliver.Relup.RunnableInstruction.insert_where/0.
Specs
log_in_upgrade_script(type :: :error | :warning | :info | :debug, message :: String.t) :: no_return
Logs the message of the given type on the node
which executes the upgrade and displays it as output of
the $APP/bin/$APP upgrade $RELEASE command. The message is
prefixed with a string derived from the message type.
Callback implementation for Edeliver.Relup.Instruction.modify_relup/2.
Specs
run(otp_application_name :: atom) :: :ok
Notifies request processes which handled http requests during the release upgrade / downgrade that the code loading is finished and that requests that failed during the code loading can be now rerun with the updated code.
Specs
warn(message :: String.t) :: no_return
Logs a warning using the Logger on the running node which is upgraded.
In addition the same warning message is logged on the node which executes
the upgrade and is displayed as output of the
$APP/bin/$APP upgarde $RELEASE command.
Macros
Assumes that the pattern matches or throws an error with the given error message.
The error message is logged as error to the logfile
using the Logger and displayed as error output by the
$APP/bin/$APP upgrade $RELEASE task using the
$APP/ebin/install_upgrade.escript script. If the pattern matches
the variables from the matching are assigned.