Setting up Cloudflare and Custom Domain on Qovery

Using Cloudflare for applications deployed on Qovery

The guide assumes that you have an application up and running on Qovery. We'll go through the process of adding a new Custom Domain to the application and use Cloudflare as the domain provider. We also assume that you own a custom domain on Cloudflare (or any other domain registrar):

Cloudflare

Adding a Custom Domain

First, let's open application settings:

Cloudflare

Add your Cloudflare managed domain in Domain section:

Cloudflare

Since your domain is behind a CDN (Cloudflare), you need to switch on the Domain behind a CDN toggle. This will automatically switch off the Generate certificate toggle because Qovery won't be able to manage it, as it will be handled by Cloudflare.

Cloudflare Configuration

CNAME

To finish the configuration on Cloudflare, open the DNS Settings:

Cloudflare

And add a CNAME entry with the value taken from the Qovery Console just like this:

Cloudflare

You can safely use the Proxy mode.

SSL/TLS

The last step to configure the domain Cloudflare side properly, is to use the Full TLS encryption:

Cloudflare

This is the requirement to make Custom Domain work properly using Cloudflare as the domain provider on Qovery.

Restrict application access

If you want to limit the application access via Cloudflare only, you have two ways to perform it:

IP whitelisting

In Qovery it is possible to whitelist a range of IPs that can reach your application:

  • In the advanced settings section of your application:

    Cloudflare

  • Get the Cloudflare ips
  • Edit the network.ingress.whitelist_source_range setting and add the Cloudflare IPs separated with a comma:

    Cloudflare

  • Save and redeploy your application

Cloudflared

Cloudflared establishes outbound connections (tunnels) between your resources and Cloudflare’s global network.

You have different ways to install Cloudflared on your cluster, you can find the installation instructions within this documentation Since Cloudflared establishes a tunnel for you and the domain and TLS management is done by Cloudflare, you don't need to expose publicly the application during the setup (See port setup

You can decide to install Cloudflared by yourself or via Qovery. Within the section below, you will find documentation on how to install Cloudflared as a container in one of the Qovery environments. By creating and deploying the following service, using the Cloudflared image:

Cloudflare

Once your tunnel is created and connected, you have to set the public hostname and the related service settings.

Cloudflare

To get the service name of your application deployed by Qovery, you can get it in your application variables:

Cloudflare

Conclusion

After following the steps from above, our application should be accessible using the custom domain we selected:

Cloudflare

In the guide we went through all the necessary steps to configure Cloudflare and Qovery to make use of your custom domain.