Skip to main content

Deploy Your Medusa Backend on Microtica

In this document, you'll learn how to deploy your Medusa backend on your AWS account with Microtica.

Overview

Microtica is a cloud-native delivery platform that enables you to deploy infrastructure and applications to your AWS account, while providing actionable insights to help you optimize resources, performance, & costs.

Alternatively, you can use this button to deploy the Medusa backend to Microtica directly:

Deploy with Microtica

The Medusa infrastructure will be provisioned on your own AWS account. You retain full control over your infrastructure and data while getting all the benefits of infrastructure automation.

What will be provisioned on AWS

Since Microtica deploys on your cloud account, here are the resources that the platform is going to provision in the environment.

  • VPC, subnets and networking
  • Container infrastructure based on Fargate
  • application load balancer
  • persistent storage
  • S3 bucket
  • Postgres database
  • and Redis (in production mode)

Prerequisites

Medusa Backend

It is assumed that you already have a Medusa backend installed locally. If you don’t, please follow the quickstart guide.

Furthermore, your Medusa backend should be configured to work with PostgreSQL and Redis. You can follow the Configure your Backend documentation to learn how to do that.

Needed Accounts

  • A Microtica account. Microtica provides a free plan that you can use.
  • An AWS account that you’ll connect to Microtica to provision the infrastructure.
  • A GitHub account to create a repository to host your backend's codebase.

Required Tools


Deploy to Microtica

Step 1: Create/Import a Git repository

Before you can deploy your Medusa backend you need to connect your preferred Git account. Microtica will create a repository on your Git account with a default repo name medusa-server.

If you already have a Medusa backend repository that you want to deploy then you need to perform a couple of changes in your source code. Follow this tutorial to deploy and existing Medusa Backend app.

Step 2: Configure the Template

The second step provides customization posibilities by configuring environment variables.

Add an application name and the admin credentials that will be used to create an initial admin user with which you can later sign in to your Medusa Admin.

Then, choose whether you want a production Medusa Backend environment or a development one. The production template will provision your managed Relational Database Service (RDS) PostgreSQL and Redis instances. On the other hand, the development template will use a local SQLite and a fake Redis instance.

Step 3: Connect an AWS account

In the last step before deployment, select the environment in which you want to deploy the template. An existing default environment called development will be preselected here, or you can create a new environment.

Then, connect your AWS account when prompted. This process takes only a few seconds, so afterward only choose the region you want to deploy in.

Step 4: Deploy to AWS

Finally, a deployment summary of what will be provisioned on your AWS account is presented. Click on the "Deploy" button to trigger a deployment of the template and start creating the infrastructure for a Medusa backend.

It will take around ten minutes for the solution to be deployed on your cloud account.

You can follow the build pipeline in real-time by clicking the "View Logs" button.

Once the build process is complete, a new deployment with the infrastructure resources is triggered. You can follow the logs of the deployment process by clicking the "View deployment" button, and then selecting the deployment from the list.


Test the Backend

After the deployment is finished, navigate to Resources → [AppName] (Medusa in this example) → Overview. Then, under the Resource Outputs section you should see the "AccessUrl". This is the backend's URL that you can use to access API endpoints and test them. You can try getting the list of products using the endpoint <AccessUrl>/store/products.

Health Route

You can access /health to get health status of your deployed backend.

Testing the Admin

Make sure to either set the autoRebuild option of the admin plugin to true or add its build command as part of the start command of your backend.

If you deployed the admin dashboard alongside the backend, you can test it by going to <AccessUrl>/app. If you changed the admin path, make sure to change /app to the path you've set.


Add Environment Variables

The environment variables can be updated, added, or configured after deployment as well. You can access them with process.env.<VARIABLE NAME>.

You can read more about the built-in environment variables, as well as how to specify custom environment variables in the Medusa backend runtime in Microtica documentation.


Updating your Deployed Backend

Any updates to the backend (for example, updating the Medusa core version) are deployed automatically when changes are committed to the repository. Microtica will handle the entire process of building and deploying your application on your connected AWS account.