Skip to content
Snippets Groups Projects
config_documentation.md 144 KiB
Newer Older
  • Learn to ignore specific revisions
  • notify_appservices_from_worker: worker1
    ```
    
    _Added in Synapse 1.59.0._
    
    ---
    ### `media_instance_running_background_jobs`
    
    The [worker](../../workers.md#synapseappmedia_repository) that is used to run
    background tasks for media repository. If running multiple media repositories
    you must configure a single instance to run the background tasks. If not provided
    this defaults to the main process or your single `media_repository` worker.
    
    Example configuration:
    ```yaml
    media_instance_running_background_jobs: worker1
    ```
    
    _Added in Synapse 1.16.0._
    
    
    Configuration for Redis when using workers. This *must* be enabled when using workers.
    
    This setting has the following sub-options:
    
    * `enabled`: whether to use Redis support. Defaults to false.
    
    * `host` and `port`: Optional host and port to use to connect to redis. Defaults to
       localhost and 6379
    
    * `path`: The full path to a local Unix socket file. **If this is used, `host` and
     `port` are ignored.** Defaults to `/tmp/redis.sock'
    
    * `password`: Optional password if configured on the Redis instance.
    
    * `dbid`: Optional redis dbid if needs to connect to specific redis logical db.
    
    * `use_tls`: Whether to use tls connection. Defaults to false.
    * `certificate_file`: Optional path to the certificate file
    * `private_key_file`: Optional path to the private key file
    * `ca_file`: Optional path to the CA certificate file. Use this one or:
    * `ca_path`: Optional path to the folder containing the CA certificate file
    
      _Changed in Synapse 1.84.0: Added use\_tls, certificate\_file, private\_key\_file, ca\_file and ca\_path attributes_
    
    
      _Changed in Synapse 1.85.0: Added path option to use a local Unix socket_
    
    
    Example configuration:
    ```yaml
    redis:
      enabled: true
      host: localhost
      port: 6379
      password: <secret_password>
    
      #use_tls: True
      #certificate_file: <path_to_the_certificate_file>
      #private_key_file: <path_to_the_private_key_file>
      #ca_file: <path_to_the_ca_certificate_file>
    
    ---
    ## Individual worker configuration
    These options configure an individual worker, in its worker configuration file.
    They should be not be provided when configuring the main process.
    
    Note also the configuration above for
    [coordinating a cluster of workers](#coordinating-workers).
    
    For guidance on setting up workers, see the [worker documentation](../../workers.md).
    
    ---
    ### `worker_app`
    
    The type of worker. The currently available worker applications are listed
    in [worker documentation](../../workers.md#available-worker-applications).
    
    The most common worker is the
    [`synapse.app.generic_worker`](../../workers.md#synapseappgeneric_worker).
    
    Example configuration:
    ```yaml
    worker_app: synapse.app.generic_worker
    ```
    ---
    ### `worker_name`
    
    A unique name for the worker. The worker needs a name to be addressed in
    further parameters and identification in log files. We strongly recommend
    giving each worker a unique `worker_name`.
    
    Example configuration:
    ```yaml
    worker_name: generic_worker1
    ```
    ---
    ### `worker_listeners`
    
    
    A worker can handle HTTP requests. To do so, a `worker_listeners` option
    must be declared, in the same way as the [`listeners` option](#listeners)
    
    Workers declared in [`stream_writers`](#stream_writers) and [`instance_map`](#instance_map)
     will need to include a `replication` listener here, in order to accept internal HTTP 
    requests from other workers.
    
    
    Example configuration:
    ```yaml
    worker_listeners:
      - type: http
        port: 8083
        resources:
          - names: [client, federation]
    ```
    
    ---
    ### `worker_manhole`
    
    A worker may have a listener for [`manhole`](../../manhole.md).
    It allows server administrators to access a Python shell on the worker.
    
    Example configuration:
    ```yaml
    worker_manhole: 9000
    ```
    
    This is a short form for:
    ```yaml
    worker_listeners:
      - port: 9000
        bind_addresses: ['127.0.0.1']
        type: manhole
    ```
    
    It needs also an additional [`manhole_settings`](#manhole_settings) configuration.
    
    
    ---
    ### `worker_daemonize`
    
    Specifies whether the worker should be started as a daemon process.
    
    If Synapse is being managed by [systemd](../../systemd-with-workers/), this option
    
    must be omitted or set to `false`.
    
    Defaults to `false`.
    
    Example configuration:
    ```yaml
    worker_daemonize: true
    ```
    ---
    ### `worker_pid_file`
    
    
    When running a worker as a daemon, we need a place to store the
    
    [PID](https://en.wikipedia.org/wiki/Process_identifier) of the worker.
    This option defines the location of that "pid file".
    
    
    This option is required if `worker_daemonize` is `true` and ignored
    
    otherwise. It has no default.
    
    See also the [`pid_file` option](#pid_file) option for the main Synapse process.
    
    Example configuration:
    ```yaml
    worker_pid_file: DATADIR/generic_worker1.pid
    ```
    ---
    ### `worker_log_config`
    
    This option specifies a yaml python logging config file as described
    [here](https://docs.python.org/3/library/logging.config.html#configuration-dictionary-schema).
    See also the [`log_config` option](#log_config) option for the main Synapse process.
    
    Example configuration:
    ```yaml
    worker_log_config: /etc/matrix-synapse/generic-worker-log.yaml
    ```
    ---
    ## Background Updates
    
    Configuration settings related to background updates.
    
    
    Background updates are database updates that are run in the background in batches.
    The duration, minimum batch size, default batch size, whether to sleep between batches and if so, how long to
    sleep can all be configured. This is helpful to speed up or slow down the updates.
    This setting has the following sub-options:
    
    * `background_update_duration_ms`: How long in milliseconds to run a batch of background updates for. Defaults to 100.
    
       Set a different time to change the default.
    * `sleep_enabled`: Whether to sleep between updates. Defaults to true. Set to false to change the default.
    * `sleep_duration_ms`: If sleeping between updates, how long in milliseconds to sleep for. Defaults to 1000.
       Set a duration to change the default.
    * `min_batch_size`: Minimum size a batch of background updates can be. Must be greater than 0. Defaults to 1.
       Set a size to change the default.
    * `default_batch_size`: The batch size to use for the first iteration of a new background update. The default is 100.
       Set a size to change the default.
    
    
    ```yaml
    background_updates:
        background_update_duration_ms: 500
        sleep_enabled: false
        sleep_duration_ms: 300
        min_batch_size: 10
        default_batch_size: 50