Cloudflare is a cloud solutions provider with a huge proprietary content delivery network (CDN). Like Netlify or Vercel, Cloudflare Pages makes the deployment process flexible and easy. You can add a GitHub repo to the service and build & host Zola-based websites after each PR automatically.
ZOLA_VERSION as a variable name. Use 0.17.2 or a different Zola version as the value.Your website is now built and deployed to Cloudflare's network! You can add a custom domain or modify settings in the Pages dashboard.
You may find documentation and guides like Getting started with Cloudflare Pages and Deploying Zola with Cloudflare Pages in the Developers portal.
When working with Cloudflare Pages, you'll often use preview deployments for testing changes before merging to your main branch. By default, these preview deployments use different URLs (like https://your-branch-name.your-project.pages.dev), which can cause issues with asset loading if your base_url is hardcoded in your zola.toml.
To fix this, modify your build command in the Cloudflare Pages configuration to dynamically set the base URL depending on the environment:
if [ "$CF_PAGES_BRANCH" = "main" ]; then zola build; else zola build --base-url $CF_PAGES_URL; fi
This command:
zola.toml base_url when building from the main branch$CF_PAGES_URL) for all other branches