Configuration

Lightbus' configuration happens in three stages:

  1. Module loading – Lightbus discovers where your bus.py file can found via the LIGHTBUS_MODULE environment variable.
  2. Service-level configuration – Your bus.py file specifies service-level settings (service_name and process_name)
  3. Global bus configuration – Your bus.py provides the location to the global config for your bus. This can be a local file path, or a HTTP(S) URL.

See the configuration explanation for further discussion and reasoning around this approach.

Configuration auto-complete using JSON Schema

Many code editors support using a JSON schema to provide auto-complete and validation when editing a JSON file. If you wish, you can write your configuration in JSON (rather than YAML), and load the following JSON schema into your editor:

https://lightbus.org/static/default-config-schema.json

This will provide you with autocomplete and validation for Lightbus' various configuration options.

If you are using custom transports or plugins you should generate your own config schema.

1. Module loading

The first stage in Lightbus' startup is to import your bus.py module. By default Lightbus will attempt to import a module named bus, but you can modify this by specifying the LIGHTBUS_MODULE environment variable.

This stage is only required when starting a Lightbus worker process (i.e. lightbus run).

Non-lightbus processes will import the bus module manually in order to access the bus client within (see next stage, below).

Note

See anatomy lesson for further discusison of the distinction between processes.

2. Service-level configuration

The bus module discovered in the module loading stage (above) must define a Lightbus client as follows:

# Must be in your bus.py file
bus = lightbus.create()

The above statement serves several purposes:

  1. The lightbus run command will use this client to access the bus.
  2. You can (and should) import this client elsewhere in the service in order to call RPCs and fire events (see how to access your bus client).
  3. You can configure service-level configuration options for your Lightbus client.

Service-level configuration is different to your global configuration because the values will vary between services.

The following service-level options are available:

# Available service-level configuration options

bus = lightbus.create(
    # Relevant to event consumption
    service_name='my_service',

    # Will be replaced 4 random characters. Default
    process_name='{random4}',

    # Path to the global bus config. 
    # Can be .yaml or .json, and http(s) URLs are supported.
    config='/path/to/lightbus.yaml',

    # Features to enable. Default is to enable all features.
    # Can be configured using the --skip and --only arguments 
    features=['rpcs', 'events', 'tasks'],
)

The above configuration options can also be set using the following environment variables or command line arguments:

Configuration option Environment Variable Command line argument Notes
Service name LIGHTBUS_SERVICE_NAME --service-name See service name explanation
Process name LIGHTBUS_PROCESS_NAME --process-name See process name explanation
Configuration path LIGHTBUS_CONFIG --config Path or URL to global configuration yaml/json file. See global bus configuration.
Features LIGHTBUS_FEATURES --only, --skip Features to enable/disable. Comma separated list of rpcs, events, tasks

Service & process name placeholders

The following placeholders may be used within your service and process name values:

Paceholder Example value Notes
{hostname} my-host Lower case hostname
{pid} 12345 The process' ID
{random4} abcd Random 4-character string
{random8} abcdefgh Random 8-character string
{random16} abcdefghijklmnop Random 16-character string
{friendly} delicate-wave-915 Human-friendly random name

Event delivery

See the events explanation section for a discussion on how service & process names affect event delivery.

3. Global bus configuration

The global bus configuration specifies the bus' overall architecture.

This configuration takes the form of a YAML or JSON file, and accordingly the filename should end with .yaml or .json.

This file is typically shared by all lightbus clients and can be specified as a path on disk, or as a HTTP(S) URL (see explanation).

A basic default configuration file is as follows:

# Root configuration
bus:
  # Bus configuration

  schema:
    # Schema configuration

    transport:
      # Transport selector config

      redis:
        url: "redis://redis.svc.cluster.local:6379/0"

apis:
  # API configuration listing

  default:
    # Api config

    event_transport:
      # Transport selector configuration
      redis:
        url: "redis://redis.svc.cluster.local:6379/0"

    rpc_transport:
      # Transport selector configuration
      redis:
        url: "redis://redis.svc.cluster.local:6379/0"

    result_transport:
      # Transport selector configuration
      redis:
        url: "redis://redis.svc.cluster.local:6379/0"

plugins:
  # Plugin configuring listing

  # These plugins ship with Lightbus
  internal_metrics:
    # Plugin configuration

    # Note that plugins are disabled by default, and must be enabled here 
    # in your bus' global configuration
    enabled: true

  internal_state:
    enabled: true
    ping_enabled: true
    ping_interval: 60

Each section is detailed below.

Root config

The available root-level configuration keys are:

The following keys are also present, but should generally not be specified in your global yaml file. Instead they should be specified for each service, as per the service-level setup:

  • service_name – Service name
  • process_name – Process name

Bus config

The bus config resides under the root config. It contains the following keys:

  • log_level (default: info) - The log level for the lightbus logger. One of debug, info, warning, error, critical. info is a good level for development purposes, warning will be more suited to production.
  • schema - Contains the schema config

Schema config

The schema config resides under the bus config.

  • human_readable (default: True) – Should the schema JSON be transmitted with human-friendly indentation and spacing?
  • ttl (default: 60) – Integer number of seconds that an API schema should live on the bus. Each schema will be pinged every ttl * 0.8 seconds in order to keep it alive. The bus will also check for new remote schemas every ttl * 0.8 seconds.
  • transport – Contains the schema transport selector

API configuration listing

The API configuration listing config resides under the root config.

This is a key/value association between APIs and their configurations. The reserved API name of default provides a catch-all configuration for any APIs without specific configurations. Specifically configured APIs do not inherit from the default configuration.

For example:

...
apis:

  # Catch-all api config
  default:
    # See 'API config'
    ... default config as above ...

  # Specific config for the 'marketing.analytics' API.
  # Use a different Redis instance for the high
  # volume marketing analytics
  marketing.analytics:
    # See 'API config'
    validate: false
    cast_values: false

    event_transport:
      redis:
        url: "redis://redis-marketing.svc.cluster.local:6379/0"

    rpc_transport:
      redis:
        url: "redis://redis-marketing.svc.cluster.local:6379/0"

    result_transport:
      redis:
        url: "redis://redis-marketing.svc.cluster.local:6379/0"

See API config for further details on the API options available.

API config

The API config resides under the API configuration listing.

APIs are configured using the options below:

  • rpc_timeout (default: 5) – Timeout when calling RPCs on this API (must also be specified on the RPC and result transport)
  • event_listener_setup_timeout (default: 1) – Timeout seconds when setting up event listeners (only applies when using the blocking api)
  • event_fire_timeout (default: 1) – Timeout seconds when firing events on the bus (only applies when using the blocking api)
  • validate – Contains the api validation config. May also be set to boolean true or false to blanket enable/disable.
  • strict_validation (default: false) – Raise an exception if we receive a message from an API for which there is no schema available on the bus. If false a warning will be emitted instead.
  • event_transport – Contains the transport selector.
  • rpc_transport – Contains the transport selector.
  • result_transport – Contains the transport selector.
  • cast_values (default: true) – If enabled, incoming values will be best-effort casted based on the annotations of the RPC method signature or event listener. See typing.
Transport selector

The schema config resides under both the API config and the schema config.

Transports are specified as follows:

... parent yaml ...
    [transport-name]:
        option: "value"
        option: "value"

Where [transport-name] can be one of:

  • redis – The redis-backed transport.
  • debug – A debug transport which logs what happens but takes no further action.

The table below details which transports can be used in which situations

Transport RPC Result Event Schema
redis
debug

Additional transports may be added in future. A single API can use different types for each of its rpc, result, and event needs.

The schema transport is global to the bus, and is not configurable on a per-api level.

For configuration details see the transport configuration reference.

API validation config

The schema config resides under the validate key within the API config.

Available options are:

  • outgoing (default true) – Validate outgoing messages against any available API schema.
  • incoming (default true) – Validate incoming messages against any available API schema.

A warning will be emitted if validation is enabled and the schema is not present on the bus. You can turn this into an error by enabling strict_validation within the API config.

Plugin configuration listing

The plugin configuration listing config resides under the root config. This configuration section is a mapping between plugin names and their configuration options.

Plugins are made available to Lightbus via the lightbus_plugins entry point (see Lightbus' setup.py for an example). As a result, installing a plugin should be sufficient for it to be made available for configuration.

Plugin developers should see the plugins reference for further details.

Plugin configuration

The Plugin configuration resides under the Plugin configuration listing.

This section provides the configuration for an individual plugin. The available configuration options will vary from plugin to plugin, so you should read the plugin's documentation for details.

However, all plugins support the enabled property, which defaults to false. You must there set enabled: true if you wish to use the plugin. For example:

bus:
  ...

apis:
  ...

plugins:
  internal_metrics:
    # Plugin configuration
    enabled: true