2021-07-18 13:02:53 -04:00
---
2021-07-19 18:02:16 -04:00
title: "Deploying Quartz to the Web"
2021-12-26 21:13:21 -05:00
tags:
- setup
2022-06-29 17:03:41 -07:00
weight: -1
2022-06-29 17:34:05 -07:00
aliases:
- hosting
2021-07-18 13:02:53 -04:00
---
2022-06-29 17:34:05 -07:00
## Hosting on GitHub Pages
2022-01-04 11:39:22 -05:00
Quartz is designed to be effortless to deploy. If you forked and cloned Quartz directly from the repository, everything should already be good to go! Follow the steps below.
2021-07-18 16:40:53 -04:00
2023-03-02 09:14:29 -08:00
### Enable GitHub Actions Permissions
By default, GitHub disables workflows from modifying your files (for good reason!). However, Quartz needs this to write the actual site files back to GitHub.
2021-07-19 00:36:15 -04:00
2023-03-02 09:14:29 -08:00
Head to `Settings > Action > General > Workflow Permissions` and choose `Read and Write Permissions`
![[notes/images/github-actions.png]]
*Enable GitHub Actions*
2021-07-19 00:36:15 -04:00
### Enable GitHub Pages
Head to the 'Settings' tab of your forked repository and go to the 'Pages' tab.
2022-02-17 10:44:39 -05:00
1. (IMPORTANT) Set the source to deploy from `master` (and not `hugo` ) using `/ (root)`
2021-07-19 00:36:15 -04:00
2. Set a custom domain here if you have one!
2021-07-19 00:40:55 -04:00
![Enable GitHub Pages ](/notes/images/github-pages.png )*Enable GitHub Pages*
2021-07-18 15:19:58 -04:00
2021-07-18 22:10:37 -04:00
### Pushing Changes
2022-02-17 10:44:39 -05:00
To see your changes on the internet, we need to push it them to GitHub. Quartz is a `git` repository so updating it is the same workflow as you would follow as if it were just a regular software project.
2021-07-18 22:18:26 -04:00
```shell
# Navigate to Quartz folder
cd < path-to-quartz >
# Commit all changes
git add .
git commit -m "message describing changes"
# Push to GitHub to update site
git push origin hugo
```
2021-07-18 22:10:37 -04:00
2022-01-04 11:39:22 -05:00
Note: we specifically push to the `hugo` branch here. Our GitHub action automatically runs everytime a push to is detected to that branch and then updates the `master` branch for redeployment.
2021-07-19 00:36:15 -04:00
### Setting up the Site
Now let's get this site up and running. Never hosted a site before? No problem. Have a fancy custom domain you already own or want to subdomain your Quartz? That's easy too.
2022-06-29 16:57:36 -07:00
Here, we take advantage of GitHub's free page hosting to deploy our site. Change `baseURL` in `/config.toml` .
2021-07-18 16:40:53 -04:00
2022-02-17 10:44:39 -05:00
Make sure that your `baseURL` has a trailing `/` !
2021-12-23 14:21:39 -08:00
[Reference `config.toml` here ](https://github.com/jackyzha0/quartz/blob/hugo/config.toml )
2021-07-18 13:02:53 -04:00
```toml
2021-07-18 16:40:53 -04:00
baseURL = "https://< YOUR-DOMAIN > /"
2021-07-18 13:02:53 -04:00
```
2021-07-18 15:19:58 -04:00
2022-06-29 16:57:36 -07:00
If you are using this under a subdomain (e.g. `<YOUR-GITHUB-USERNAME>.github.io/quartz` ), include the trailing `/` . **You need to do this especially if you are using GitHub!**
2021-12-23 14:21:39 -08:00
```toml
baseURL = "https://< YOUR-GITHUB-USERNAME > .github.io/quartz/"
```
2021-07-19 00:36:15 -04:00
Change `cname` in `/.github/workflows/deploy.yaml` . Again, if you don't have a custom domain to use, you can use `<YOUR-USERNAME>.github.io` .
2022-02-17 10:44:39 -05:00
Please note that the `cname` field should *not* have any path `e.g. end with /quartz` or have a trailing `/` .
2021-12-23 14:21:39 -08:00
[Reference `deploy.yaml` here ](https://github.com/jackyzha0/quartz/blob/hugo/.github/workflows/deploy.yaml )
2021-07-18 16:40:53 -04:00
2022-07-01 11:27:50 -07:00
```yaml {title=".github/workflows/deploy.yaml"}
2021-07-18 16:40:53 -04:00
- name: Deploy
uses: peaceiris/actions-gh-pages@v3
with:
2021-07-19 00:36:15 -04:00
github_token: ${{ secrets.GITHUB_TOKEN }} # this can stay as is, GitHub fills this in for us!
2021-07-18 16:40:53 -04:00
publish_dir: ./public
publish_branch: master
cname: < YOUR-DOMAIN >
```
2022-01-27 09:38:28 -08:00
Have a custom domain? [Learn how to set it up with Quartz ](notes/custom%20Domain.md ).
2021-07-19 18:02:16 -04:00
2022-06-29 16:57:36 -07:00
### Ignoring Files
Only want to publish a subset of all of your notes? Don't worry, Quartz makes this a simple two-step process.
❌ [Excluding pages from being published ](notes/ignore%20notes.md )
2022-11-20 15:09:58 -08:00
## Docker Support
If you don't want to use a hosting service, you can host using [Docker ](notes/docker.md ) instead!
I would *not use this method* unless you know what you are doing.
2021-07-19 18:02:16 -04:00
---
2021-07-18 16:40:53 -04:00
Now that your Quartz is live, let's figure out how to make Quartz really *yours* !
2022-06-29 16:57:36 -07:00
> Step 6: 🎨 [Customizing Quartz](notes/config.md)
2021-07-18 16:40:53 -04:00
2021-12-23 14:21:39 -08:00
Having problems? Checkout our [FAQ and Troubleshooting guide ](notes/troubleshooting.md ).