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.
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