GitHub Pages で Nuxt をデプロイする
Nuxt アプリケーションを GitHub Pages でどうやってデプロイするのか?
Nuxtは、例えば GitHub Pages のような任意の静的ホスティング上で Web アプリケーションのホストすることができます。
GitHub Pages 上にデプロイするために、静的 Web アプリケーションを生成する必要があります:
npm run generate
これにより、dist
フォルダが作成され、その中には GitHub Pages のホスティングにデプロイするためのすべてのものが入っています。プロジェクトのリポジトリにはブランチ gh-pages
を、ユーザーや組織サイトにはブランチ master
を指定します。
CNAME
ファイルを設置する場合は、static
ディレクトリに CNAME ファイルを設置することを推奨します。これについては、より詳細なドキュメント を参照してください。リポジトリを GitHub Pages にデプロイする
まず、GitHub pages でホストしているため、static target を使用していることを確認してください:
export default {
target: 'static'
}
特定のリポジトリ用に GitHub Pages を作成し、カスタムドメインを持たない場合、ページの URL は次のような形式になります。http://<ユーザー名>.github.io/<リポジトリ名>
となります。
router base を追加せずに dist
フォルダをデプロイした場合、デプロイされたサイトにアクセスすると、アセットが不足しているためにサイトが動作していないことがわかります。これは、ウェブサイトのルートが /
であると仮定しているが、この場合は /<リポジトリ名>
であるためです。
この問題を解決するには、router base という設定を nuxt.config.js
に追加する必要があります:
export default {
target: 'static',
router: {
base: '/<repository-name>/'
}
}
こうすることで、生成されたパスアセットの先頭にはすべて /<リポジトリ名>/
が付き、次にコードをリポジトリの GitHub Pages にデプロイしたときに、サイトが正しく動作するようになります。
コマンドラインによるデプロイ
push-dir パッケージ も使うことができます:
まず npm でそれをインストールします:
npm install push-dir --save-dev
プロジェクトのリポジトリであればブランチを gh-pages
に、ユーザーや組織のサイトであればブランチを master
として、package.json
に deploy
コマンドを追加してください。
"scripts": {
"dev": "nuxt",
"generate": "nuxt generate",
"start": "nuxt start",
"deploy": "push-dir --dir=dist --branch=gh-pages --cleanup"
},
その後、静的なアプリケーションを生成し、デプロイします:
npm run generate
npm run deploy
ビルドサーバーのデプロイ
デプロイメントをさらに一歩進めて、手動でローカルインストールからファイルをコンパイルしてデプロイするのではなく、ビルドサーバーを利用して GitHub リポジトリの新しいコミットを監視し、自動的にチェックアウト、コンパイル、デプロイを行うことができます。
GitHub Actions
GitHub を使ったソフトウェア自動化のための公式ツールである GitHub Actions を使ってデプロイするためには、ワークフローを持っていない場合、新しいワークフローを作成するか、既存のワークフローに新しいステップを追加する必要があります。
これは、GitHub Pages Action を使用しており、生成されたファイルを dist
フォルダからデフォルトの GitHub Pages ブランチ gh-pages
にプッシュします。
既存のワークフローで、次のステップを追加します:
- name: Deploy
uses: peaceiris/actions-gh-pages@v3
with:
github_token: ${{ secrets.GITHUB_TOKEN }}
publish_dir: ./dist
新しいワークフローでは、以下の内容を .github/workflows
ディレクトリの cd.yml
という新しいファイルに貼り付けます:
name: cd
on: [push, pull_request]
jobs:
cd:
runs-on: ${{ matrix.os }}
strategy:
matrix:
os: [ubuntu-latest]
node: [14]
steps:
- name: Checkout
uses: actions/checkout@master
- name: Setup node env
uses: actions/setup-[email protected]
with:
node-version: ${{ matrix.node }}
- name: Install dependencies
run: yarn
- name: Generate
run: yarn run generate
- name: Deploy
uses: peaceiris/actions-gh-pages@v3
with:
github_token: ${{ secrets.GITHUB_TOKEN }}
publish_dir: ./dist
そして、これを自分のリポジトリにコミットします:
git add .github/workflows/cd.yml
git commit -m "Adding github pages deploy workflow"
git push origin
完了すると、gh-pages
ブランチが更新され、サイトも更新されているのがわかります。
Travis CI
オープンソースプロジェクト向けの無料ビルドサーバーである Travis CI を使ってデプロイするには、GitHub アカウントでサインインし、Travis にリポジトリを閲覧する権限を与え、表示されたリストのリポジトリ名の横にあるスイッチを切り替えて、リポジトリのビルドサーバーを有効にします。
次に、リポジトリ名の横にある歯車のアイコンをクリックして、ビルドサーバの一般的な設定を行い、スイッチを切り替えて 'Build only if .travis.yml is present' 機能を有効にします。
同じ画面で Environment Variables セクションにスクロールダウンし、GITHUB_ACCESS_TOKEN
という名前の新しい変数を作成します。値の欄には、先ほど作成した GitHub パーソナルアクセストークンのコピーを貼り付けて、'Add' ボタンをクリックします。
最後に、リポジトリのルートに以下の内容の .travis.yml
設定ファイルを作成します。
language: node_js
node_js:
- '12'
cache:
directories:
- 'node_modules'
branches:
only:
- master
install:
- npm install
- npm run generate
script:
- echo "Skipping tests"
deploy:
provider: pages
skip-cleanup: true
github-token: $GITHUB_ACCESS_TOKEN # travis-ci.orgのダッシュボードに設定され、安全とマークされます https://docs.travis-ci.com/user/deployment/pages/#Setting-the-GitHub-token
target-branch: gh-pages
local-dir: dist
on:
branch: master
そして、これをリポジトリにコミットします
git add .travis.yml
git commit -m "Adding travis deploy configuration"
git push origin
これで、リポジトリに何か変更をコミットすると、Travis の中で、新しいビルドが開始されます
そして完了すると、GitHub pages のサイトが自動的に更新されているのがわかります。
Appveyor
オープンソースプロジェクト向けの無料ビルドサーバーである Appveyor を使ってデプロイするには、新規アカウントにサインアップし、GitHub 認証オプションを選択して、GitHub アカウントを使ってサインインします。
一度サインインしたら、'New project' リンクをクリックし、表示されたリストのリポジトリ名の横にある 'Add' ボタンをクリックして、リポジトリのビルドサーバーを有効にします。
次に、リポジトリのルートに、以下の内容の appveyor.yml
設定ファイルを作成します
environment:
# Nuxtにはnode v12以上が必要です
nodejs_version: '12'
# 機密データの暗号化 (https://ci.appveyor.com/tools/encrypt)
github_access_token:
secure: ENCRYPTED_GITHUB_ACCESS_TOKEN
github_email:
secure: ENCRYPTED_GITHUB_EMAIL
# master ブランチでのみ実行
branches:
only:
- master
# インストールスクリプト (repoのクローニング後に実行されます)
install:
# nodejs バージョンをスイッチ
- ps: Install-Product node $env:nodejs_version
# モジュールをインストール
- npm install
# 静的ファイルを生成
- npm run generate
# グローバル git クレデンシャルストアの設定 (https://www.appveyor.com/docs/how-to/git-push/)
- git config --global credential.helper store
- ps: Add-Content "$env:USERPROFILE\.git-credentials" "https://$($env:github_access_token):x-oauth-[email protected]`n"
- git config --global user.email $env:github_email
# GitHub pages へのデプロイ
- npm run deploy
# テストを実行しない
test: off
# 実際にはビルドしない
build: off
NB この設定では、コマンドラインによるデプロイ の指示に従って、package.json
ファイルが設定されていることを前提としています。
ただし、このファイルをコミットする前に、ENCRYPTED_GITHUB_ACCESS_TOKEN
と ENCRYPTED_GITHUB_EMAIL
変数に、先ほどの GitHub パーソナルアクセストークンと、Appveyor encryption tool を使って暗号化した GitHub のメールアドレスを設定しておく必要があります。
一度更新したら、そのファイルをリポジトリにコミットします
git add appveyor.yml
git commit -m "Adding appveyor deploy configuration"
git push origin
これで、Appveyor 内でリポジトリに変更をコミットすると、新しいビルドが開始されることになります
完了すると、GitHub pages のサイトが自動的に更新されているのがわかります。
data:image/s3,"s3://crabby-images/c079f/c079f408bc783e75be10a58380dcd8f75fc6fe30" alt="Sébastien Chopin"
data:image/s3,"s3://crabby-images/a36f1/a36f155e74808db2757a1b6265083d6a6d4fc94c" alt="Nazaré da Piedade"
data:image/s3,"s3://crabby-images/96e50/96e5023b65c2d33f36fe7c3eac0a0c96b238658e" alt="Nobu"
data:image/s3,"s3://crabby-images/f29a0/f29a0d620d87519a52cfd0ae8e69128a162a7b67" alt="川音리오"
data:image/s3,"s3://crabby-images/2677d/2677de88513b8010c060962c34aeb67dac770a18" alt="Maciek Palmowski"
data:image/s3,"s3://crabby-images/404a5/404a58aea4ef3c54629ba26fc32a51d6e2a18a5f" alt="Nestor Vera"
data:image/s3,"s3://crabby-images/98a40/98a40243e9a287aa704ef3dc22e5fc28e59b7574" alt="Daniel Roe"
data:image/s3,"s3://crabby-images/b7385/b7385c01953ba5d76898a41fb5b24feb98bc4bb2" alt="Yue Yang"
data:image/s3,"s3://crabby-images/2a3d1/2a3d1e419f61998b33f62e14cf9b5a4783aa7794" alt="Jeronimas"
data:image/s3,"s3://crabby-images/b336a/b336a791a4de2d8cb75b955cb90eabf2879b83a5" alt="Clément Ollivier"
data:image/s3,"s3://crabby-images/37dca/37dcaf7d38f5846b7c5c9c391f5918a51ccd934c" alt="Alexander Lichter"
data:image/s3,"s3://crabby-images/a27d2/a27d2e6048cbb2955844e53dd5ec8a75e08ea2cd" alt="N3-rd"
data:image/s3,"s3://crabby-images/d6a94/d6a9457c88e2400fa917f2d9ae084e5b1a1cb517" alt="Adrien Zaganelli"
data:image/s3,"s3://crabby-images/e2529/e2529558cb857cbf0010c38a88b255deea628bdf" alt="Mag"
data:image/s3,"s3://crabby-images/5b539/5b5399cdda0f1d2b5b03e847623b619a64ac1d0f" alt="Stefan Huber"
data:image/s3,"s3://crabby-images/2b5ad/2b5ad589e7cc4f5c0babe7670eefddc43968146e" alt="Olga Bulat"
data:image/s3,"s3://crabby-images/c30e9/c30e9a86a4692d5c123c90220ddca7a458e17e35" alt="Paiva"
data:image/s3,"s3://crabby-images/5d4bf/5d4bff0bf543f1ad8ce5610ae03bb5c2901dc1df" alt="Florian Reuschel"
data:image/s3,"s3://crabby-images/b8800/b8800632d3225a51be4bed995e635716c72d6761" alt="Savas Vedova"
data:image/s3,"s3://crabby-images/3eb50/3eb5088ee9bebfb29c66604180d5f1786dcc288e" alt="HIJACK"
data:image/s3,"s3://crabby-images/ba3ff/ba3ffe962ceab2637a46936c4b3832823bb0f5e8" alt="Vinícius Alves"
data:image/s3,"s3://crabby-images/75fcf/75fcfe777c70ebb7577bde2a0c2e2f82512da323" alt="Kareem Dabbeet"
data:image/s3,"s3://crabby-images/da55d/da55d7a86e3c71ef5371bfcd5fbf9faaed6ddc51" alt="Valentín Costa"
data:image/s3,"s3://crabby-images/9d225/9d22581d38ab2acd1069230435358270c09a5128" alt="Ryan Skinner"
data:image/s3,"s3://crabby-images/c9d3b/c9d3b3b0b99544192e54a41ae709bd992c32794f" alt="Alex Hirzel"
data:image/s3,"s3://crabby-images/a66f5/a66f51077e5283065acdcf5249a88a6dcda457b7" alt="Ajeet Chaulagain"
data:image/s3,"s3://crabby-images/cc775/cc77528ad32d6df1c92dcd7819df9c709e7aae17" alt="René Eschke"
data:image/s3,"s3://crabby-images/4f930/4f9307ea6d868688a41bce88daa5e734dd7b4f30" alt="Nico Devs"
data:image/s3,"s3://crabby-images/642a4/642a45e9f53437a0dc0786dad3822b47542ab41e" alt="Muhammad"
data:image/s3,"s3://crabby-images/578b7/578b7a4826d9e9c79b10c0a440bf6023cac8634d" alt="Naoki Hamada"
data:image/s3,"s3://crabby-images/18000/18000ed7b913e1a5ef0c301cec202908424f2b36" alt="Tom"
data:image/s3,"s3://crabby-images/f2eaa/f2eaafbc890bdba93ddfc694d9ceb7a59bf21a4c" alt="Yann Aufray"
data:image/s3,"s3://crabby-images/28706/2870667dfa80efaff50559c179c068fbf01ef205" alt="Anthony Chu"
data:image/s3,"s3://crabby-images/18462/18462ffca9a6899eec5a54b7de6a45887d0729c8" alt="Nuzhat Minhaz"
data:image/s3,"s3://crabby-images/9f43b/9f43ba42692b50b513a0f9fee1d9c100d0c9f177" alt="Lucas Portet"
data:image/s3,"s3://crabby-images/87bb8/87bb8cdadf010bc5ead4801489bb088532a79443" alt="Richard Schloss"
data:image/s3,"s3://crabby-images/6bf20/6bf2065989faa4ad57a63c65a21c0d4918a0dd73" alt="Bobby"
data:image/s3,"s3://crabby-images/c5e5e/c5e5e61af957ba4bebf4242162f8db94d3da7ca1" alt="bpy"
data:image/s3,"s3://crabby-images/bbc3f/bbc3fdf0e5e37795f6a3a8267834e6b3b9cdb8ce" alt="Antony Konstantinidis"
data:image/s3,"s3://crabby-images/3ba7a/3ba7a27e05f9691d23fa8d0b28e16355254be5ec" alt="Hibariya"
data:image/s3,"s3://crabby-images/e12ba/e12ba2b49b19dd4dee0cab2dee520f022fc39436" alt="Jose Seabra"
data:image/s3,"s3://crabby-images/ab2b3/ab2b3791f0b93c3d266a07a7331e8c639c45b840" alt="Eze"
data:image/s3,"s3://crabby-images/fe12d/fe12d1c0b546b012067bd695ea18752e750c162f" alt="Florian Lefebvre"
data:image/s3,"s3://crabby-images/3f4be/3f4bee239f7004d6c28c9006fd5b9bb5ad3cae9e" alt="Lucas Recoaro"
data:image/s3,"s3://crabby-images/736af/736af6fee3723bd40ca1a4cea3f57ece7f182b15" alt="Julien SEIXAS"