You may see a 502 error with the message
Registered endpoints failed to handle the request when you try to visit your URL. This means that the request failed, despite the fact that our system thought there was a healthy container at the beginning of the request.
This often happens because your backend wasn’t able to respond, when communicating with our proxy servers. You may need to profile your app to determine the cause of this error. Check the Logs tab to potentially find out more information about the issue.
Your app may throw a 503 error and show
Service Unavailable: No healthy endpoints to handle the request when you try to visit your URL. This means no healthy containers are currently available to serve your app.
Potential reasons for this include:
- all containers are unhealthy, because they are all stuck in a CPU loop
- no containers are running, because they are stopped or because every container crashed (especially if the total number of your containers is 1, and your app hasn’t had time to restart)
- your build failed, if this is the first time you’re deploying a container for that app or if the only other available containers built successfully but are unhealthy
The most common cause of the 503 error is a problem in your code that prevents deployment - a deployment failure. Check the Logs tab to potentially find out more information about the issue.
A common reason that your app may be crashing on startup is that your
MONGO_URL variable is missing or is set incorrectly. You can verify what
MONGO_URL Galaxy is using by going to the app’s dashboard and choosing the settings tab. To learn how to set it correctly, check the following resources:
- Environment variables will show you how to set up your
- This compose.io article explains the settings for
If you believe your
MONGO_URL is set correctly, try the following:
- Check the app dashboard and verify the app status is green (healthy).
dig +show [your app's domain]in the terminal and verify that its CNAME points to Galaxy. You can learn how to set up DNS here.
- If you are in the US region, your CNAME should point to
- If you are in the EU region, your CNAME should point to
- If you are in the Asia-Pacific region, your CNAME should point to
- If you are in the US region, your CNAME should point to
If you recently changed your DNS settings, you may need to wait for the new records to propagate. DNS changes often propagate within 30 minutes (depending on the TTL configured for the record set), but in some cases it can take up to 24 hours. Contact your DNS provider if you think there is a problem.
Module missing or npm error
This usually indicates that the module or package working locally in your application is not working after deployment. While we don’t offer support for the use of specific third-party packages, an explanation may help you to troubleshoot.
When you deploy an app, we bundle node_modules into it; npm packages that are required on the client side get built into the bundle uploaded to Galaxy. Galaxy doesn’t need to run
npm install for client side bundling to work.
Note that dynamic requires may cause issues. An example would be using
require(variable) instead of
require("fixed-name"). To avoid this, put
require("react/package.json") somewhere in your app’s code to ensure it gets bundled.
You may find the
meteor npm install --save package command to be helpful, where
package should be replaced with the name of the package you are trying to install. This will add the package to your package.json file, using the latest version and any needed dependencies.
Alternatively, you can specify the package name directly in your package.json file, with the version number and any necessary dependencies.
A common type of npm error will show up during the build process, in the ‘All’ or ‘Service’ tab of your logs. If you were deploying an example package using version number 1.0.0, it would show up as follows:
Failed at the email@example.com install script 'prebuild --install'
This means that this package failed to install, using that version. A long term solution may involve either communicating with the package maintainer, or the Meteor release manager, to massage the issue. In the short term, the best immediate solution usually involves changing the version - either of the package version, or of the Meteor version, if builds suddenly start failing upon upgrading to a new Meteor version.
If you happen to be using an older version of Meteor, consider updating to a more recent version, as that has been known to resolve issues in the past.
If you’ve been using
npm, consider using
meteor npm instead, as you may run into conflicts in the former case.
If neither of these solutions work, try removing the package entirely, and making any necessary adjustments to your app to accommodate this change.
A recommended method for emulating Galaxy is to run locally with
--production. The way node_modules are pulled in is different on a remote deployment to a server (including Galaxy) than when building locally. The
--production setting will minimize and concatenate all the JS into one file.
Package not compatible
Apps that contain local packages with NPM dependencies which include binary components will fail to deploy to Galaxy by default. You’ll know you’ve run into this issue when a
meteor deploy to Galaxy fails with
[package] is not compatible with architecture 'os.linux.x86\_64 (where [package] is replaced by the package name that is causing the issue).
Version 1.2.1 of Meteor (and higher) provides the
METEOR_BINARY_DEP_WORKAROUND environment variable for Galaxy deployment. To deploy your app to Galaxy using the workaround:
- Upgrade your app to Meteor version 1.2.1 or higher with
- Next, deploy to galaxy by setting the
METEOR_BINARY_DEP_WORKAROUND=tenvironment variable. An example deploy command would look like
METEOR_BINARY_DEP_WORKAROUND=t DEPLOY_HOSTNAME=galaxy.meteor.com meteor deploy ..., replacing
...with the rest of your deployment command (URL, settings, etc.).
If you are uncertain if this matches your situation, you can use this test app to reproduce the error and confirm a fix.