AppSignal for Elixir: Diagnose tool

The AppSignal for Elixir package ships with a self diagnostic tool. This tool can be used to debug your AppSignal installation and is one of the first thing our support team asks for when there's an issue.

This tool has been available since version 0.12.0 of the AppSignal for Elixir package.

The diagnostic report

This command line tool is useful when testing AppSignal on a system and validating the local configuration. It outputs useful information to debug issues and it checks if AppSignal agent is able to run on the machine's architecture and communicate with the AppSignal servers.

This diagnostic tool collects and outputs the following:

  • information about the AppSignal package.
  • information about the host system, Elixir and Erlang.
  • if the AppSignal extension and agent can run on the host system.
  • all configured config options (including default values).
  • if the configuration is valid and active.
  • if the Push API key is present and valid (internet connection required).
  • where configuration option values originate from.
  • if the required system paths exist, are writable, and which user and group are owners.
  • small parts of the tail from the available log files.

Read more about how to use the diagnose command on the Debugging page.

Submitting the report

Since package version 1.3.0 you will be prompted to send the report to AppSignal. If accepted the report will be send to our servers and you will receive a support token.

When you send this support token to us we will review the report and help you debug the issue. We've seen that copy-pasting the report output usually loses formatting and makes it harder to read, which is why it's send to our servers in the JSON format.

In package version 1.9.0 the option was added to view the report yourself on AppSignal.com. A link to the report is printed in the diagnose output. This web view will also show any validation problems and warnings our system detected.

Usage

On the command line in your project:

bash
mix appsignal.diagnose

With an Elixir release binary

If your Elixir app is packaged in an Elixir release binary, built with mix release you will not be able to call the task using mix. Instead use the eval command on your release binary to call the AppSignal task diagnose like so:

bash
bin/your_app eval ":appsignal_tasks.diagnose()"

With a release binary

If your Elixir app is packaged in a release binary with a tool such as distillery you will not be able to call the task using mix. Instead use the command command on your release binary to call the AppSignal task diagnose like so:

bash
bin/your_app command appsignal_tasks diagnose

Options

OptionDescription
Environment optionSet the environment to use in the command, e.g. production or staging.
--[no-]send-reportAutomatically send, or do not send the report.

Environment option

Select a specific environment with the CLI.

bash
MIX_ENV=prod mix appsignal.diagnose

The environment option is useful when the default environment is not the one you want to diagnose. The diagnose tool will warn you when no environment is selected.

Report submission option

The options to submit the report immediately, or not, were added to the AppSignal package version 1.9.0. Selecting whether or not to send the report with these options will no longer prompt this question, making it easier to use in non-interactive environments.

Submit the report to AppSignal:

bash
mix appsignal.diagnose --send-report

Do not submit the report to AppSignal:

bash
mix appsignal.diagnose --no-send-report

Configuration output format

Configuration option values format

The configuration options are printed to the CLI as their inspected values. This means we print them as Elixir would in a console.

  • Strings values are printed with double quotes around them, e.g. "My app name".
  • Booleans values are printed as their raw values: true and false.
  • List values are printed as a collection of values surrounded by square brackets, e.g. ["HTTP_ACCEPT", "HTTP_ACCEPT_CHARSET"].
    • Empty Lists are printed as two square brackets: [].
  • Nil values are printed as nil.

Configuration sources

The configuration section also prints where values from config options come from. This may help by identifying sources that override values from other config sources.

For more on which configuration sources are available and in which order they're loaded and thus their priority, see the configuration load order page.

The configuration options are printed as demonstrated below depending on where the configuration option value comes from and how many sources set this option.

shell
Configuration # Option with a value loaded only from the default source send_params: true # Option with one source # A different source than the default source name: "My app name" (Loaded from file) # Option with multiple sources # Listed in order of priority (highest priority last) active: true Sources: default: false file: false env: true

Exit codes

  • Exits with status code 0 if the command has completed successfully.
  • Exits with status code 1 if the command has completed with an error.