View Source ProcessHub.Strategy.Distribution.Base protocol (ProcessHub v0.4.0-beta)

The distribution strategy protocol defines behaviour to identify the nodes which are responsible for a child process.

Summary

Types

t()

All the types that implement this protocol.

Functions

Returns the list of nodes where the child process belongs to.

Perform any necessary initialization and validation for the started children.

Triggered when coordinator is initialized.

Types

@type t() :: term()

All the types that implement this protocol.

Functions

Link to this function

belongs_to(strategy, hub, child_ids, replication_factor)

View Source
@spec belongs_to(
  strategy :: struct(),
  hub :: ProcessHub.Hub.t(),
  child_ids :: [ProcessHub.child_id()],
  replication_factor :: pos_integer()
) :: [{ProcessHub.child_id(), [node()]}]

Returns the list of nodes where the child process belongs to.

The list of nodes is used to determine where the child process should be started or migrated to.

Link to this function

children_init(strategy, hub, child_specs, opts)

View Source
@spec children_init(struct(), ProcessHub.Hub.t(), [map()], keyword()) ::
  :ok | {:error, any()}

Perform any necessary initialization and validation for the started children.

@spec init(
  struct(),
  ProcessHub.Hub.t()
) :: struct()

Triggered when coordinator is initialized.

Could be used to perform initialization.