---
Quartz effectively turns your Markdown files and other resources into a bundle of HTML, JS, and CSS files (a website!).
However, if you'd like to publish your site to the world, you need a way to host it online. This guide will detail how to deploy with either GitHub Pages or Cloudflare pages but any service that allows you to deploy static HTML should work as well (e.g. Netlify, Replit, etc.)
| Configuration option | Value |
|---|---|
| Production branch | v4-alpha |
| Framework preset | None |
| Build command | npx quartz build |
| Build output directory | public |
Press "Save and deploy" and Cloudflare should have a deployed version of your site in about a minute. Then, every time you sync your Quartz changes to GitHub, your site should be updated.
To add a custom domain, check our Cloudflare's documentation.
Like Quartz 3, you can deploy the site generated by Quartz 4 via GitHub Pages.
In your local Quartz, create a new file quartz/.github/workflows/deploy.yaml.
name: Deploy Quartz site to GitHub Pages
on:
push:
branches:
- v4-alpha
permissions:
contents: read
pages: write
id-token: write
concurrency:
group: "pages"
cancel-in-progress: false
jobs:
build:
runs-on: ubuntu-22.04
steps:
- uses: actions/checkout@v2
with:
fetch-depth: 0 # Fetch all history for git info
- uses: actions/setup-node@v3
with:
node-version: 18.14
- name: Install Dependencies
run: npm ci
- name: Build Quartz
run: npx quartz build
- name: Upload artifact
uses: actions/upload-pages-artifact@v2
with:
path: public
deploy:
needs: build
environment:
name: github-pages
url: ${{ steps.deployment.outputs.page_url }}
runs-on: ubuntu-latest
steps:
- name: Deploy to GitHub Pages
id: deployment
uses: actions/deploy-pages@v2
Then, commit these changes by doing npx quartz sync. This should deploy your site to <github-username>.github.io/<repository-name>.
Here's how to add a custom domain to your GitHub pages deployment.
example.com) or a subdomain (subdomain.example.com).
A record that points your apex domain to GitHub's name servers which have the following IP addresses:
185.199.108.153185.199.109.153185.199.110.153185.199.111.153CNAME record that points your subdomain to the default domain for your site. For example, if you want to use the subdomain quartz.example.com for your user site, create a CNAME record that points quartz.example.com to <github-username>.github.io.![[dns-records.png]]*The above shows a screenshot of Google Domains configured for both jzhao.xyz (an apex domain) and quartz.jzhao.xyz (a subdomain).*
See the GitHub documentation for more detail about how to setup your own custom domain with GitHub Pages.
[!question] Why aren't my changes showing up?
There could be many different reasons why your changes aren't showing up but the most likely reason is that you forgot to push your changes to GitHub.Make sure you save your changes to Git and sync it to GitHub by doing
npx quartz sync. This will also make sure to pull any updates you may have made from other devices so you have them locally.