165 lines
5.6 KiB
Markdown
165 lines
5.6 KiB
Markdown
|
---
|
||
|
title: Deploy Site
|
||
|
prev: /docs/guide/shortcodes
|
||
|
next: /docs/advanced
|
||
|
---
|
||
|
|
||
|
Hugo generates static websites, allowing for flexible hosting options.
|
||
|
This page provides guides for deploying your Hextra site on various platforms.
|
||
|
|
||
|
<!--more-->
|
||
|
|
||
|
|
||
|
## GitHub Pages
|
||
|
|
||
|
[GitHub Pages](https://docs.github.com/pages) is the recommended way to deploy and host your website for free.
|
||
|
|
||
|
If you bootstrap the site using [hextra-starter-template](https://github.com/imfing/hextra-starter-template), it has provided GitHub Actions workflow out-of-the-box that helps automatically deploy to GitHub Pages.
|
||
|
|
||
|
{{% details title="GitHub Actions Configuration" closed="true" %}}
|
||
|
|
||
|
Below is an example configuration from [hextra-starter-template](https://github.com/imfing/hextra-starter-template):
|
||
|
|
||
|
```yaml {filename=".github/workflows/pages.yaml"}
|
||
|
# Sample workflow for building and deploying a Hugo site to GitHub Pages
|
||
|
name: Deploy Hugo site to Pages
|
||
|
|
||
|
on:
|
||
|
# Runs on pushes targeting the default branch
|
||
|
push:
|
||
|
branches: ["main"]
|
||
|
|
||
|
# Allows you to run this workflow manually from the Actions tab
|
||
|
workflow_dispatch:
|
||
|
|
||
|
# Sets permissions of the GITHUB_TOKEN to allow deployment to GitHub Pages
|
||
|
permissions:
|
||
|
contents: read
|
||
|
pages: write
|
||
|
id-token: write
|
||
|
|
||
|
# Allow only one concurrent deployment, skipping runs queued between the run in-progress and latest queued.
|
||
|
# However, do NOT cancel in-progress runs as we want to allow these production deployments to complete.
|
||
|
concurrency:
|
||
|
group: "pages"
|
||
|
cancel-in-progress: false
|
||
|
|
||
|
# Default to bash
|
||
|
defaults:
|
||
|
run:
|
||
|
shell: bash
|
||
|
|
||
|
jobs:
|
||
|
# Build job
|
||
|
build:
|
||
|
runs-on: ubuntu-latest
|
||
|
env:
|
||
|
HUGO_VERSION: 0.121.2
|
||
|
steps:
|
||
|
- name: Checkout
|
||
|
uses: actions/checkout@v4
|
||
|
with:
|
||
|
fetch-depth: 0 # fetch all history for .GitInfo and .Lastmod
|
||
|
submodules: recursive
|
||
|
- name: Setup Go
|
||
|
uses: actions/setup-go@v5
|
||
|
with:
|
||
|
go-version: '1.21'
|
||
|
- name: Setup Pages
|
||
|
id: pages
|
||
|
uses: actions/configure-pages@v4
|
||
|
- name: Setup Hugo
|
||
|
run: |
|
||
|
wget -O ${{ runner.temp }}/hugo.deb https://github.com/gohugoio/hugo/releases/download/v${HUGO_VERSION}/hugo_extended_${HUGO_VERSION}_linux-amd64.deb \
|
||
|
&& sudo dpkg -i ${{ runner.temp }}/hugo.deb
|
||
|
- name: Build with Hugo
|
||
|
env:
|
||
|
# For maximum backward compatibility with Hugo modules
|
||
|
HUGO_ENVIRONMENT: production
|
||
|
HUGO_ENV: production
|
||
|
run: |
|
||
|
hugo \
|
||
|
--gc --minify \
|
||
|
--baseURL "${{ steps.pages.outputs.base_url }}/"
|
||
|
- name: Upload artifact
|
||
|
uses: actions/upload-pages-artifact@v3
|
||
|
with:
|
||
|
path: ./public
|
||
|
|
||
|
# Deployment job
|
||
|
deploy:
|
||
|
environment:
|
||
|
name: github-pages
|
||
|
url: ${{ steps.deployment.outputs.page_url }}
|
||
|
runs-on: ubuntu-latest
|
||
|
needs: build
|
||
|
steps:
|
||
|
- name: Deploy to GitHub Pages
|
||
|
id: deployment
|
||
|
uses: actions/deploy-pages@v4
|
||
|
```
|
||
|
|
||
|
{{% /details %}}
|
||
|
|
||
|
|
||
|
{{< callout >}}
|
||
|
In your repository settings, set the **Pages** > **Build and deployment** > **Source** to **GitHub Actions**:
|
||
|

|
||
|
{{< /callout >}}
|
||
|
|
||
|
By default, the above GitHub Actions workflow `.github/workflows/pages.yaml` assumes that the site is deploying to `https://<USERNAME>.github.io/<REPO>/`.
|
||
|
|
||
|
If you are deploying to `https://<USERNAME>.github.io/` then modify the `--baseURL`:
|
||
|
|
||
|
```yaml {filename=".github/workflows/pages.yaml",linenos=table,linenostart=54,hl_lines=[4]}
|
||
|
run: |
|
||
|
hugo \
|
||
|
--gc --minify \
|
||
|
--baseURL "https://${{ github.repository_owner }}.github.io/"
|
||
|
```
|
||
|
|
||
|
If you are deploying to your own domain, please change the `--baseURL` value accordingly.
|
||
|
|
||
|
|
||
|
## Cloudflare Pages
|
||
|
|
||
|
1. Put your site source code in a Git repository (e.g. GitHub)
|
||
|
2. Log in to the [Cloudflare dashboard](https://dash.cloudflare.com/) and select your account
|
||
|
3. In Account Home, select **Workers & Pages** > **Create application** > **Pages** > **Connect to Git**
|
||
|
4. Select the repository, and in the **Set up builds and deployments** section, provide the following information:
|
||
|
|
||
|
| Configuration | Value |
|
||
|
| ----------------- | -------------------- |
|
||
|
| Production branch | `main` |
|
||
|
| Build command | `hugo --gc --minify` |
|
||
|
| Build directory | `public` |
|
||
|
|
||
|
For more details, check out:
|
||
|
- [Deploy a Hugo site](https://developers.cloudflare.com/pages/framework-guides/deploy-a-hugo-site/#deploy-with-cloudflare-pages).
|
||
|
- [Language support and tools](https://developers.cloudflare.com/pages/platform/language-support-and-tools/).
|
||
|
|
||
|
|
||
|
## Netlify
|
||
|
|
||
|
1. Push your code to your Git repository (GitHub, GitLab, etc.)
|
||
|
2. [Import the project](https://app.netlify.com/start) to Netlify
|
||
|
3. If you are not using [hextra-starter-template][hextra-starter-template], configure the following manually:
|
||
|
- Configure the Build command to `hugo --gc --minify`
|
||
|
- Specify the Publish directory to `public`
|
||
|
- Add Environment variable `HUGO_VERSION` and set to `0.119.0`
|
||
|
4. Deploy!
|
||
|
|
||
|
Check [Hugo on Netlify](https://docs.netlify.com/integrations/frameworks/hugo/) for more details.
|
||
|
|
||
|
|
||
|
## Vercel
|
||
|
|
||
|
1. Push your code to your Git repository (GitHub, GitLab, etc.)
|
||
|
2. Go to [Vercel Dashboard](https://vercel.com/dashboard) and import your Hugo project
|
||
|
3. Configure the project, select Hugo as Framework Preset
|
||
|
4. Override the Build Command and Install command:
|
||
|
1. Set Build Command to `hugo --gc --minify`
|
||
|
2. Set Install Command to `yum install golang`
|
||
|
|
||
|

|