兼ねてより試してみたかった Gatsby.js + Vercel の組み合わせに着手してみました。
Gatsby.js のインストールと Gitリポジトリ の準備
まずは Gatsby.js のプロジェクトを作って Gitホスティングサービス に push します。
> yarn init
## 略
success Saved package.json
Done in 2.33s.
適当なディレクトリで package.json
を生成。
> yarn add gatsby-cli
## 略
Done in 26.05s.
続いて gatsby-cli
をインストールします。一応グローバルではなくローカルで。
今回のテーマはこれにします。
> gatsby new mptotkb https://github.com/renyuanz/leonids
╔════════════════════════════════════════════════════════════════════════╗
║ ║
║ Gatsby collects anonymous usage analytics ║
║ to help improve Gatsby for all users. ║
║ ║
║ If you'd like to opt-out, you can use `gatsby telemetry --disable` ║
║ To learn more, checkout https://gatsby.dev/telemetry ║
║ ║
╚════════════════════════════════════════════════════════════════════════╝
info Creating new site from git: https://github.com/renyuanz/leonids.git
Cloning into 'mptotkb'...
remote: Enumerating objects: 60, done.
remote: Counting objects: 100% (60/60), done.
remote: Compressing objects: 100% (44/44), done.
Receiving objects: 100% (60/60), 542.69 KiB | 5.32 MiB/s, done.eceiving objects: 100% (60/60)
success Created starter directory layout
info Installing packages...
info Preferred package manager set to "npm"
## 略
Your new Gatsby site has been successfully bootstrapped. Start developing it by running:
cd mptotkb
gatsby develop
プロジェクト作成完了。
> cd mptotkb
> gatsby develop
## 略
info
Hi from the Gatsby maintainers! Based on what we see in your site, these coming
features may help you. All of these can be enabled within gatsby-config.js via
flags (samples below)
Preserve webpack's Cache (https://github.com/gatsbyjs/gatsby/discussions/28331), which changes Gatsby's cache clearing behavior to not clear webpack's
cache unless you run "gatsby clean" or delete the .cache folder manually.
Here's how to try it:
module.exports = {
flags: { PRESERVE_WEBPACK_CACHE: true },
plugins: [...]
}
⠀
You can now view gatsby-starter-leonids in the browser.
⠀
http://localhost:8000/
⠀
View GraphiQL, an in-browser IDE, to explore your site's data and schema
⠀
⠀
Note that the development build is not optimized.
To create a production build, use gatsby build
⠀
success Building development bundle - 48.261s
OK。完了しました。
最初は手始めということでこの状態でいったん push しておきたいと思います。 Gitリポジトリ に登録するのは親ディレクトリではなく作成したプロジェクト (今回は mptotkb
下) です。
data:image/s3,"s3://crabby-images/dbadc/dbadc8da7ca571d2e440bfe322efe9e827d9cabe" alt="GitHub でリポジトリを作成"
GitHub でリポジトリを作成して、このリポジトリに先ほどのプロジェクトを push 。ちなみにリポジトリは public である必要があります。
Vercel と Gitホスティングサービス の連携
次に Vercel でアカウントを作ります。
data:image/s3,"s3://crabby-images/2ad5c/2ad5ce65b2c10f747414a3a83da531cc92a7da16" alt="Vercel で Sign Up をクリック"
Sign Up をクリック。
data:image/s3,"s3://crabby-images/7dca7/7dca7198d4985f1c539c648d27a15f3931cba474" alt="GitHub と連携"
今回は GitHub を使用しているので「Continue with GitHub」を選択。
data:image/s3,"s3://crabby-images/4217f/4217f52f861693ee336065c3c4000d5a4a252def" alt="Vercel のアクセスを認証して権限を付与"
「Authorize Vercel」で Vercel のアクセスを認証します。
data:image/s3,"s3://crabby-images/4e072/4e072a5394797cf2347c674a312932fde8b50172" alt="Vercel にログイン成功"
ログインできました。
リポジトリのインポート
data:image/s3,"s3://crabby-images/5dc3c/5dc3c00867cd42c379cc35843f0e812bc61f2329" alt="ダッシュボードから「New Project」"
一度中断してしまったのでダッシュボードから。ここからであれば「New Project」で次へ進みます。
data:image/s3,"s3://crabby-images/42045/42045064e5306d1af8f08650148662a344c9eea0" alt="Import Git Repository から「Add GitHub Org or Account」"
Import Git Repository から「Add GitHub Org or Account」。
data:image/s3,"s3://crabby-images/3008a/3008ae46e72b234840beb2948338ba6b12f56348" alt="インポートするリポジトリを選択"
インポートするリポジトリを選択します。今回は1つのリポジトリだけに Vercel に連携させます。
data:image/s3,"s3://crabby-images/fd85e/fd85e6e1863ff5dc97ff8086eb3e00ca0e35c864" alt="リポジトリの確認"
リポジトリの確認です。使用しているフレームワークが自動判別されるのはありがたいですね。
data:image/s3,"s3://crabby-images/82062/820626f233344da1b768b793db3bf3c2533e5a48" alt="チームの作成は「Skip」"
次の画面でフローに沿って設定を進めていきます。最初に Vercel のチームを作成する画面が有効になっていますが、今回は個人なので「Skip」。
data:image/s3,"s3://crabby-images/6bf93/6bf93d1457a15131e4f2b3ed188d6779d9f79fe3" alt="Configure Project"
プロジェクトの設定。出力の設定や環境変数を設定できますが、今回はそのままで。
data:image/s3,"s3://crabby-images/8c16a/8c16a7aa88cc83c70a573e8128eb895bf9bfd97a" alt="デプロイ中"
デプロイ中。
data:image/s3,"s3://crabby-images/4cb6e/4cb6e4fb71d76c9da4cd76d0b212fc1c4e7973c2" alt="デプロイされた画面を実際に確認"
少し待つとデプロイが完了します。そこでURLから実際の画面を表示させると……きちんとデプロイされていました!
ここまでで Gatsby.js + Vercel でブログを作成することができました。
今後の課題としては以下の通り。
- サイト名や著者情報といった基本情報のカスタマイズ
- どうやらブログ記事の Markdown ファイルを生成する CLI やユーティリティはなさそうで、手作業で記事をちまちま作っていくのは手間なので記事リソースを別の場所 (Headless CMS とか) で管理して JAMStack にする
あとは折角なので GraphQL にも少しは触ってみたいところですね。
参考
Gatsby.js + Vercel
- 【ZEIT Now】Gatsbyサイトを無料サーバーVercelで公開する方法を徹底解説 | WebCraftLog
- Gatsby + microcms + Vercel でブログを作って公開したい
- Vercel – Git – Vercel Documentation
- 参考記事とは画面構成が変わっていたため、最終的には Vercel のドキュメントが頼りでした