Python Configuration

Configuration Options

The Python agent can be configured via three methods:

  1. Scout Config
  2. Framework dependent variables
  3. Environment Variables

Scout Config

from scout_apm.api import Config

Config.set(
    key="[AVAILABLE IN THE SCOUT UI]",
    name="A FRIENDLY NAME FOR YOUR APP",
    monitor=True,
)

Framework Dependent

Certain frameworks have other ways that Scout variables can be configured, such as in settings.py for Django and app.config for Flask. See framework pages for more details.

Environment Variables

You can also configure Scout APM via environment variables. To configure Scout via environment variables, uppercase the config key and prefix it with SCOUT_. For example, to set the key configuration via environment variables use: export SCOUT_KEY=YOURKEY

Common Configurations

Setting Name Description Default Required
key The organization API key. Yes
name Name of the application (ex: ‘Photos App’). Yes
monitor Whether monitoring data should be reported. False Yes
revision_sha The Git SHA associated with this release. Used with Deploy Tracking. See docs No

Additional Configurations

Setting Name Description Default Required
collect_remote_ip Automatically capture end user IP addresses as part of each trace’s context. True No
disabled_instruments An list of instruments that Scout should not install. If specified as an environment variable, it should be a comma-separated list. The default installed instruments can be viewed in the agent source. [] No
errors_ignored_exceptions Excludes certain exceptions from being reported. () No
hostname The hostname the metrics should be aggregated under. hostname No
log_payload_content Logs the payload of the messages being sent to the core-agent and error service. This should only be enabled for debugging. False No
sample_rate Gobal sample rate for your application. Rate should be 1-100 serving as a percentage of requests to capture (ex: 80 to capture 80% of requests). 100 No
endpoint_sample_rate Sample rate for all endpoints. Overriden by individual endpoint sampling. Rate should be 1-100 serving as a percentage of requests to capture. 100 No
job_sample_rate Sample rate for all jobs. Overriden by individual job sampling. Rate should be 1-100 serving as a percentage of requests to capture. 100 No
ignore_endpoints An Array of web endpoints that Scout should not instrument. Routes that match the prefixed path (ex: ['/health', '/status']) will be ignored by the agent. Replaces old ignore configuration. [] No
ignore_jobs An Array of job names that Scout should not instrument. Jobs with exact name match will be ignored by the agent. [] No
sample_endpoints An Array of web endpoints that Scout should sample at the provided rate (ex: ['/busy_endpoint:50']). Rate should be 1-100 serving as a percentage of requests to capture. [] No
sample_jobs An Array of job names that Scout should sample at the provided rate (ex: ['MyJob:70']). Rate should be 1-100 serving as a percentage of requests to capture. [] No
log_content_payload Logs the payload of the messages being sent to the core-agent and error service. This should only be enabled for debugging. False No
scm_subdirectory The relative path from the base of your Git repo to the directory which contains your application code. No
showdown_timeout_seconds Maximum amount of time, in seconds, to spend at flushing outstanding events to the core agent at shutdown. Set to 0 to disable. 2.0 No
uri_reporting By default Scout reports the URL and filtered query parameters with transaction traces and error reports. Sensitive parameters in the URL will be redacted. To exclude query params entirely, use path. filtered_params No

Core Agent Configurations

There are also some configuration options that affect how the core agent process is run. Typically you don’t need to change these:

Setting Name Description Default Required
core_agent_dir Path to create the directory which will store the Core Agent. /tmp/scout_apm_core No
core_agent_download Whether to download the Core Agent automatically, if needed. True No
core_agent_full_name The release/url we look for when downloading the core-agent. Auto-detected No
core_agent_launch Whether to start the Core Agent automatically, if needed. True No
core_agent_log_file The log file for the Core Agent to write its logs to. If not set, it won’t be written. This does not affect the logging configuration of the Python library. To change that, directly configure the python logging module as per the below documentation. Prior to version 2.13.0, this was called log_file. That name now works as an alias, and takes precedence to allow old configuration to continue to work. No
core_agent_log_level The log level of the Core Agent. This should be one of: "trace", "debug", "info", "warn", "error". This does not affect the log level of the Python library. To change that, directly configure the python logging module as per the below documentation. Prior to version 2.6.0, this was called log_level. That name now works as an alias, and takes precedence to allow old configuration to continue to work. "info" No
core_agent_permissions The permission bits to set when creating the directory of the Core Agent. 700 No
core_agent_config_file Point to a configuration file for the Core Agent. This may be useful for debugging your setup with files provided by Scout APM staff. Prior to version 2.13.0, this was called config_file. That name now works as an alias, and takes precedence to allow old configuration to continue to work. No
core_agent_triple If you are running a MUSL based Linux (such as ArchLinux), you may need to explicitly specify the platform triple. E.g. x86_64-unknown-linux-musl Auto detected No
core_agent_socket_path The path to the socket to connect to the Core Agent, passed to it when launching. This may be either a TCP address, in the format tcp://<address>:<port>, or an absolute path to create as a Unix socket. The deafult is to use TCP. Prior to version 2.16.0, this defaulted to using a Unix socket in the same directoy as the core agent. Prior to version 2.13.0, this was called socket_path. That name now works as an alias, and takes precedence to allow old configuration to continue to work. tcp://127.0.0.1:6590 No

Environments

It typically makes sense to treat each environment (production, staging, etc) as a separate application within Scout and ignore the development and test environments. Configure a unique app name for each environment as Scout aggregates data by the app name.

Ex:

export SCOUT_KEY=YOURKEY
export SCOUT_NAME=YOURAPPNAME (Production)