sidebar_position | description |
---|---|
3 |
This page provides you common deployment errors and troubleshooting instructions to fix them. |
import Tabs from "@theme/Tabs"; import TabItem from "@theme/TabItem";
If you encounter the error that ports 80 & 443
aren't open, its is recommended that you stop all processes on these ports and start again. If the processes on these ports cannot be stopped, you can run appsmith on another port.
-
In the file
docker-compose.yml
, change the ports for the Nginx container to a custom port as shown in the below example.ports: - "80:80" - "443:443" - "9001:9001"
Change to
ports: - "8080:80" - "8443:443" - "9801:9001"
-
Run
docker-compose up -d
:::tip To stop a previous version of appsmith running on these ports, run the following:
sudo su
docker container kill $(docker ps -q)
:::
If you chose to initialize a new database and are seeing this error, it could be due to an error while fetching dependencies during installation. Deleting the current installation direction, killing the docker containers, and restarting the installation should work. If it doesn't, please reach out on discord
If you are trying to connect to an existing MongoDB and the containers failed to start it may be due to one of the following reasons:
- Incorrect MongoDB credentials
- Empty Salt / Password for encryption
Restart the installation process with valid values.
- Ensure your security groups are configured to allow traffic to ports 80 & 443 on your installation instance.
- You can access the running application on localhost in any browser or the
public IP
of your machine. - You may need to wait for a few minutes before accessing the application to allow Nginx to start.
If your deployment is behind an ELB / Proxy, you must update the Nginx configuration of the deployment. In the file data/nginx/nginx.app.conf.template
modify the line:
proxy_set_header X-Forwarded-Proto $scheme;
with
proxy_set_header X-Forwarded-Proto $http_x_forwarded_proto;
This ensures that the redirect URLs are correct during OAuth2 logins. This works even if the ELB is configured to run on a custom port.
In release v1.6.4
, Appsmith upgraded its libraries & Spring framework. This caused a compatibility issue between the libraries used within Appsmith and the version of MongoDB that was shipped earlier. This didn't show up in testing because all testing happened against MongoDB clusters with replica sets, where the problem doesn't surface.
If you see an error like the below, your instance is affected by the library upgrade performed in v1.6.4
.
Caused by: com.mongodb.MongoCommandException: Command failed with error 17 (ProtocolError): 'Attempt to switch database target during SASL authentication.' on server mongo:27017. The full response is {"ok": 0.0, "errmsg": "Attempt to switch database target during SASL authentication.", "code": 17, "codeName": "ProtocolError"}
Please follow the steps mentioned below to fix your Appsmith installation.
Adding &authSource=admin
to the end of your APPSMITH_MONGODB_URI
variable’s value in your docker.env
file. For example, in your docker.env
file, if you have the following line:
# Old config
APPSMITH_MONGODB_URI=mongodb://<your_username>:<your_password>@mongo/appsmith?retryWrites=true
Change it to the following (notice the only change is &authSource=admin
. Please don't paste this whole line. Only add the &authSource=admin
part to your current value.
# New config
APPSMITH_MONGODB_URI=mongodb://<your_username>:<your_password>@mongo/appsmith?retryWrites=true&authSource=admin
Save the file.
Now restart your container with the following command:
sudo docker-compose up -d --force-recreate appsmith-internal-server
In a minute or two, the server should now come up and be ready.
If you are having trouble with invitation emails not being sent, even though the Admin email setup is able to send test emails, it may be due to an issue with the configuration of the email parameters.
If you aren't receiving the invitation email, please check the value for APPSMITH_REPLY_TO
in the configuration file. If this value is empty, please set it to the same email address that you are using for APPSMITH_MAIL_FROM
and restart the application.
This should resolve the issue of not receiving the invitation email. Additionally, it may be helpful to verify that the email server being used is working correctly and there are no issues with the network or other components preventing the emails from being sent.
However, if you encounter any issues, you can contact the support team on Discord or ask questions on the community forum.
The instance keeps restarting due to a server shutdown displaying a schema mismatch error.
<Message messageContainerClassName="error" messageContent="Looks like you skipped some required updates, please go back to the mandatory upgrade path v1.9.2"
As the error message in the server logs suggests, your Appsmith instance has missed a required checkpoint upgrade. This occurs if you are manually upgrading and have skipped a version or are on an automatic upgrade but your instance hasn't checked for updates for a particular period.
To resolve this error, you must upgrade to the checkpoint version, in this case, v1.9.2
.
To prevent similar issues in the future, consider enabling auto updates for your Appsmith instance. If you already had auto updates on and still encountered this issue, please contact the Appsmith team to determine the cause of the deployment problem
MongoDB fails to start, after migrating to MongoDB version 5.
<Message
messageContainerClassName="error"
messageContent="Illegal instruction (core dumped) mongod –fork –port 27017 –dbpath
“$MONGO_DB_PATH"
MongoDB version 5 has specific CPU requirements. If these requirements are not met the server wouldn't start.
To resolve this error, you must upgrade your infrastructure. See the List of complaint hardware.
If it is not possible for you to upgrade your infrastructure to support MongoDB version 5 or higher:
- You may use an external MongoDB version 5 or higher on MongoDB Atlas.
- If you are upgrading your infrastructure and need time, consider downgrading Appsmith. Once you have upgraded MongoDB, Update Appsmith to the latest version to use new features.
Follow the steps below to downgrade to v1.8.15:
- Access your Appsmith instance and make the below change to the
docker-compose.yml
file:
```yaml
services:
appsmith:
#highlight-next-line
image: index.docker.io/appsmith/appsmith-ce:v1.8.15
container_name: appsmith
```
</TabItem>
<TabItem value="commercialEdition" label="Commercial Edition">
```yaml
services:
appsmith:
#highlight-next-line
image: index.docker.io/appsmith/appsmith-ee:v1.8.15
container_name: appsmith
```
</TabItem>
- Run the restart command:
docker-compose up -d
Your server starts with version 1.8.15, which makes all the necessary schema changes to your Appsmith instance.
This issue occurs while upgrading your Appsmith Business or Enterprise Helm charts from version 3.0.4
to 3.0.7
and results in an upgrade failure.
<Message messageContainerClassName="error" messageContent="UPGRADE FAILED: unable to build kubernetes objects from current release manifest: resource mapping not found for name: '' namespace: '' from '': no matches for kind 'HorizontalPodAutoscaler' in version 'autoscaling/v2beta1' ensure CRDs are installed first"
The issue happens because of how Helm handles the upgrade. During an upgrade, Helm compares your existing application configuration with the new chart, verifying the updated/supported API versions. When Kubernetes removes an API version, the Go Client library can no longer understand the deprecated objects. This results in an error when Helm interacts with the library, causing the upgrade to fail.
To resolve this issue, use the helm-mapkubeapis plugin. This plugin helps Helm understand the changes made in Kubernetes.
Follow these steps to solve the issue:
- Install the
helm-mapkubeapis
plugin with:helm plugin install https://github.com/helm/helm-mapkubeapis
- Verify the plugin installation with:
helm plugin ls
- Apply the plugin to the Appsmith Helm chart with (replace
<APPSMITH-CHART_NAME>
and<NAMESPACE>
with the chart name and the your namespace):helm mapkubeapis <APPSMITH-CHART-NAME> -n <NAMESPACE>
- Update the Appsmith installation with:
helm upgrade -i appsmith-ee appsmith-ee/appsmith -n appsmith-ee -f values.yaml