Please note that you need to set up a PostgreSQL database manually to be used by ToolJet. Additionally, you must set up a Redis service through Azure Cache for Redis. We've provided detailed configuration steps in the [Redis Setup](#redis-setup) section.
1. Open the [Azure dashboard](https://portal.azure.com) and navigate to Container Apps, then click on **Create container app**.
<imgclassName="screenshot-full"src="/img/setup/azure-container/step1.png"alt="Deploying ToolJet on Azure container apps"/>
2. Select the appropriate subscription and provide basic details such as the container name and then click on the **Create new environment** button below "Container Apps environment" to configure the networking setup.
<imgclassName="screenshot-full"src="/img/setup/azure-container/step2.png"alt="Deploying ToolJet on Azure container apps"/>
3. Configure the basic settings as shown in the screenshot below.
4. Move to the "Networking" tab for the detailed configuration as shown in the screenshot. You can retain the default settings for Workload Profiles and Monitoring configurations.
:::tip
The Container app, the PostgreSQL server, and the Redis server all should be in the same virtual network (VNet).
:::
<imgclassName="screenshot-full"src="/img/setup/azure-container/step3-2.png"alt="Deploying ToolJet on Azure container apps"/>
5. Click on the **Create** button at the bottom of the page.
6. In the container tab, uncheck the "Use quickstart image" option to select the image source manually.
<imgclassName="screenshot-full"src="/img/setup/azure-container/step3-v2.png"alt="Deploying ToolJet on Azure container apps"/>
Make sure to provide the image tag, and then enter `server/entrypoint.sh, npm, run, start:prod` in the "Arguments override" field.
Add the following ToolJet application variables under the "Environmental variable" section. You can refer to this [**documentation**](/docs/setup/env-vars) for more information on environment variables.
**Note**: ToolJet requires:
```
TOOLJET_DB
TOOLJET_DB_HOST
TOOLJET_DB_USER
TOOLJET_DB_PASS
PG_HOST
PG_DB
PG_USER
PG_PASS
SECRET_KEY_BASE
LOCKBOX_KEY
```
For redis connection ensure below environment variables are added:
```
REDIS_HOST
REDIS_PORT
REDIS_USER
```
If using Azure Database for Postgresql-Flexible server, add:
7. In the ingress tab, configure Ingress and Authentication settings as shown below. You can customize the security configurations as per your requirements. Make sure the port is set to 3000.
New LTS versions are released every 3-5 months with an end-of-life of atleast 18 months. To check the latest LTS version, visit the [ToolJet Docker Hub](https://hub.docker.com/r/tooljet/tooljet/tags) page. The LTS tags follow a naming convention with the prefix `LTS-` followed by the version number, for example `tooljet/tooljet:ee-lts-latest`.
If this is a new installation of the application, you may start directly with the latest version. This guide is not required for new installations.
#### Prerequisites for Upgrading to the Latest LTS Version:
- It is crucial to perform a **comprehensive backup of your database** before starting the upgrade process to prevent data loss.
- Users on versions earlier than **v2.23.0-ee2.10.2** must first upgrade to this version before proceeding to the LTS version.