Tkan珈琲専門店

AstroとCloudflare Pagesでブログを作った

投稿日: 2023-04-17 17:00

AstroとCloudflare Pagesでブログを作った

Astro を利用してブログを作成しました。ホスト先には Cloudflare Pages を利用しています。

選定理由

Astro

Astro はコンテンツが豊富な Web サイトを構築するためのフレームワークです。

Astro was designed for building content-rich websites. This includes most marketing sites, publishing sites, documentation sites, blogs, portfolios, and some ecommerce sites. 1

今回はブログを作りたかったので、静的サイトジェネレータをいくつか調べていました。 Hugo は以前に利用したことがありそれ以外を検討していたのですが、Astro は以下の点に魅力を感じたので選択しました。

Cloudflare Pages

Astro では静的サイトが生成されるので、ホスト先の選択肢は豊富です。 GitHub Pages、Cloudflare Pages、Netlify、Vercel などがよく選ばれているようなので、その中で検討しました。

導入から公開までやったこと

サイトは GitHub へ公開しているのでそのコミットを貼りつつ、どんなことをしたか書いていきます。

ブログテンプレートを生成

Terminal window
npm create astro@latest -- --template blog
╭─────╮ Houston:
Let's make the web weird!
╰─────╯
astro v2.3.0 Launch sequence initiated.
dir Where should we create your new project?
./blog
◼ tmpl Using blog as project template
✔ Template copied
deps Install dependencies?
Yes
✔ Dependencies installed
ts Do you plan to write TypeScript?
Yes
use How strict should TypeScript be?
Strict
✔ TypeScript customized
git Initialize a new git repository?
Yes
✔ Git initialized
next Liftoff confirmed. Explore your project!
Enter your project directory using cd ./blog
Run npm run dev to start the dev server. CTRL+C to stop.
Add frameworks like react or tailwind using astro add.
Stuck? Join us at https://astro.build/chat
╭─────╮ Houston:
│ ◠ ◡ ◠ Good luck out there, astronaut! 🚀
╰─────╯

基本的な情報の更新

URL、サイトタイトルの変更

https://github.com/tkancf/tkancf.com/commit/eb4c2fa535b591b2d50ae0400952b3fa55cacb46

コピーライト部分の変更 Twitter、GitHub アカウントの URL を自分のものに変更

Prettier のフォーマットが働いてしまって diff がでかくなってます... https://github.com/tkancf/tkancf.com/commit/763fff1bc69d1a828b8c646a5da398ce7ce02df5

アバウトページの更新

https://github.com/tkancf/tkancf.com/commit/4ba74d011265211f14ff17201a1ddae7a9f6bc09

トップページの更新

https://github.com/tkancf/tkancf.com/commit/80ff54a1eda4d53e9db2f2c90d398042c26a2178

画像ファイルの更新

https://github.com/tkancf/tkancf.com/commit/46673876dd7d41b8d08a49576155300cff64b702

.node-version ファイルを追加

この指定がない場合、デフォルトでは 12.18.0 が利用されるのですが、これだとビルドが失敗してしまうので .node-version ファイルに Node.js のバージョンを指定しておきます。

https://github.com/tkancf/tkancf.com/commit/80c890626dbd4742ecb83d9694343451069107b0

Cloudflare Pages で公開

Pages の画面から Create a project => Connect to Git => repository の選択 などを進めていくだけのぽちぽち作業。簡単です。

robots.txt の追加

テンプレートには robots.txt が存在していなかったので、本当に最低限のものを用意しました。 https://github.com/tkancf/tkancf.com/commit/9db9e7c09c78a7e0c00c81f92fcfb1795ff9295f

User-agent: *
Allow: /
Sitemap: https://example.com/sitemap-index.xml

jpeg 画像を webp へ変換

jpeg 画像が重く PageSpeed Insights のパフォーマンスが 93 点になっていたため、webp へ変換しました。 https://github.com/tkancf/tkancf.com/commit/591fdc4d0df85b532434ce396ec123a726ee46dc

変換前の PageSpeed Insights の点数 PageSpeed Insightsで93点の画像

変換後の PageSpeed Insights の点数

PageSpeed Insightsで100点の画像

変換後は無事 100 点になりました。

終わりに

こんな感じで簡単に公開することが出来ました。今後デザインの変更などもやっていこうかと思っています。 ブログ以外にも Astro を利用して作ってみたいコンテンツがあるので、色々遊びたいです。 また、Cloudflare Pages を調べる中で Cloudflare Workers というのがあるのを知れたので、これも試してみようと思います。

Footnotes

  1. Why Astro?: https://docs.astro.build/en/concepts/why-astro/#content-focused