Running multiple applications on one host

The problem

When running multiple applications on one host some odd behavior may occur. One common problem we've seen is that Applications start reporting under different names and/or environments. Such as an application switching between the staging and production environment after a deploy or restart of an application process or worker.

Background

The AppSignal agent starts using an application config. It uses this configuration to send the data to the AppSignal servers to report it as that app on AppSignal.com.

By default AppSignal is configured to assume one application runs on one host. If you run more than one application on a host, some configuration is required to avoid sharing the AppSignal working directory between multiple applications. This way multiple AppSignal agents can run at the same time with a different application config.

🔍 Read more about the AppSignal working directory.

Configuration

To allow AppSignal to be used for multiple applications on one host we need to set the "working directory path" configuration option. Using this configuration option, we need to set a unique working directory path per application for AppSignal to store its (temporary) files. This way the AppSignal agent will not share the working directory between multiple applications.

Ruby

To set the working directory path in the Ruby integration, add the following to your AppSignal configuration file. The working_directory_path value is an existing path on your host system.

# Example: config/appsignal.yml
production:
  working_directory_path: "/tmp/project_1/"

Read more

Elixir

To set the working directory path in the Elixir integration, add the following to your AppSignal configuration file. The working_directory_path value is an existing path on your host system.

# Example: config/appsignal.exs
config :appsignal, :config,
  working_directory_path: "/tmp/project_1/"

Read more

Node.js

To set the working directory path in the Node.js integration, add the following to your AppSignal configuration file. The workingDirectoryPath value is an existing path on your host system.

// Example: appsignal.js
const { Appsignal } = require("@appsignal/nodejs");
 
const appsignal = new Appsignal({
  // Other config
  workingDirectoryPath: "/tmp/project_1",
});
 
module.exports = { appsignal };

Read more

Front-end JavaScript

No working directory can be configured for Front-end JavaScript applications as it does not rely on the AppSignal agent process. If data is reported for the wrong application, please make sure the application is using the correct Push API key

See also

Want to help us improve this documentation page?

Create a pull request

Need more help?

Contact us and speak directly with the engineers working on AppSignal. They will help you get set up, tweak your code and make sure you get the most out of using AppSignal.

Contact us

Start a trial - 30 days free

AppSignal is a great way to monitor your Ruby, Elixir & Node.js applications. Works great with Rails, Phoenix, Express and other frameworks, with support for background jobs too. Let's improve your apps together.

Start a trial