On launching Baserow if you encountered the "Backend URL mis-configuration detected" or you are having trouble connecting to your Baserow server this tutorial will explain why this error can occur how to fix it.
Baserow needs to know the hostname where it hosted for a number of practical and
security reasons. It cannot safely discover this hostname automatically and instead
relies on you setting it correctly. In the docker and docker-compose installs it
defaults to using http://localhost
. If you then try to access Baserow from a different
machine your browser will still be configured to look for Baserow at http://localhost
,
which does not exist on the different machine, which is the usual cause of this error.
Ensure you have set the environment variable BASEROW_PUBLIC_URL
to the URL you are
using the access Baserow on. The following three sections show how to do this depending
on how you are accessing your Baserow server.
If you are accessing your Baserow server using a domain name then you should launch Baserow like so:
docker run \
-e BASEROW_PUBLIC_URL=https://YOUR_DOMAIN_HERE \
# ... followed by the rest of your normal baserow docker arguments
If you are accessing your Baserow server using a domain name and you want the Baserow
Caddy server to automatically handle HTTPS for you then launch Baserow like so. If
you still want to be able to access your Baserow from http://localhost add
,http://localhost
onto the BASEROW_CADDY_ADDRESSES.
docker run \
-e BASEROW_PUBLIC_URL=https://YOUR_DOMAIN_HERE \
-e BASEROW_CADDY_ADDRESSES=https://YOUR_DOMAIN_HERE \
# ... followed by the rest of your normal baserow docker arguments
If you are accessing your Baserow server using an IP address then you should launch Baserow like so:
docker run \
-e BASEROW_PUBLIC_URL=http://YOUR_IP_ADDRESS_HERE \
# ... followed by the rest of your normal baserow docker arguments
If you have or want to access Baserow using a different port other than 80 (-p 80:80
)
then you also need to set the environment variable WEB_FRONTEND_PORT
. You also need
to ensure you properly change the -p 80:80
argument to
-p YOUR_CUSTOM_PORT:80
and also update the BASEROW_PUBLIC_URL to include
the port at the end.
Please note that ports 3000, 5432, 1085 and 8000 are already bound to within the Docker container and so you should pick a different port for YOUR_CUSTOM_PORT. This is because the embedded Caddy reverse proxy listens for connections at $BASEROW_PUBLIC_URL, and so by adding a port onto this you will also make Caddy inside the container listen on that port.
docker run \
-e BASEROW_PUBLIC_URL=https://YOUR_IP_OR_DOMAIN_HERE:YOUR_CUSTOM_PORT \
-e WEB_FRONTEND_PORT=YOUR_CUSTOM_PORT \
-p YOUR_CUSTOM_PORT:80 \
# ... followed by the rest of your normal baserow docker arguments
Ensure you have set the environment variable BASEROW_PUBLIC_URL
to the URL you are
using the access Baserow on. See the
Install with docker compose guide
to see the various ways you can set this variable using docker compose.
The following three sections show how to do this depending on how you are accessing your Baserow server. Please remember to also include any additional environment variables and arguments that are explained in the guide above.
If you are accessing your Baserow server using a domain name then you should launch Baserow like so
BASEROW_PUBLIC_URL=https://YOUR_DOMAIN_HERE docker-compose up -d
If you are accessing your Baserow server using a domain name and you want the Baserow
Caddy server to automatically handle HTTPS for you then launch Baserow like so. If
you still want to be able to access your Baserow from http://localhost add
,http://localhost
onto the BASEROW_CADDY_ADDRESSES.
BASEROW_PUBLIC_URL=https://YOUR_DOMAIN_HERE \
BASEROW_CADDY_ADDRESSES=https://YOUR_DOMAIN_HERE \
docker-compose up -d
If you are accessing your Baserow server using an IP address then you should launch Baserow like so:
BASEROW_PUBLIC_URL=https://YOUR_IP_HERE docker-compose up -d
If you have or want to access Baserow using a different port other than 80 and
then you also need to set the environment variable WEB_FRONTEND_PORT
.
BASEROW_PUBLIC_URL=https://YOUR_IP_OR_DOMAIN_HERE:YOUR_CUSTOM_PORT \
WEB_FRONTEND_PORT=YOUR_CUSTOM_PORT \
docker-compose up -d
Baserow also provides the baserow/backend
and baserow/web-frontend
images for users
who want to host and co-ordinate the various Baserow services themselves. Using
these images you instead need to set the following environment variables on all
containers running these images. Please note that the BASEROW_PUBLIC_URL
environment
variable is not used by these standalone images.
PUBLIC_BACKEND_URL
(defaulthttp://localhost:8000
): The publicly accessible URL of the backend. Should include the port if non-standard.PRIVATE_BACKEND_URL
(defaulthttp://backend:8000
): Not only the browser, but also the web-frontend server should be able to make HTTP requests to the backend. It might not have access to thePUBLIC_BACKEND_URL
or there could be a more direct route, (e.g. from container to container instead of via the internet). In case of the development environment the backend container be accessed via thebackend
hostname and because the server is also running on port 8000 inside the container, the private backend URL should behttp://backend:8000
.PUBLIC_WEB_FRONTEND_URL
(defaulthttp://localhost:3000
): The publicly accessible URL of the web-frontend. Should include the port if non-standard.
Please post on the community forum if you are having further troubles or are using another installation method.