寄付支援サイト part2 -SPA&サーバレス-
前回は寄付支援サイトを作ろうと思った理由について述べました。
part2では技術的な挑戦内容を(勉強しながら)まとめます。
本プロジェクトでは以下の技術・概念の理解・習熟を目指します。
- SPA(シングルページアプリケーション)
- サーバレスアーキテクチャ
SPA(シングルページアプリケーション)とは
はじめに一枚のHTMLをロードし、以降はユーザの操作に応じて動的にページを書き換えていくウェブアプリです。
通常ウェブサイトを開くと、ページ遷移の度にHTMLとかCSSとかJSとかを読み込みます。
でもダブりが多く、それだけ無駄に通信していることになります。
SPAでは必要な部分だけを書き換えるのでレスポンスが高速になります。
サーバレスアーキテクチャとは
AWS Lambdaに代表されるFaaS(Function as a Service)やBaaS(Backend as a Service)で構成されたアーキテクチャです。
オンプレのサーバやEC2ではサーバごとにOSやミドルウェアの管理をしなくてはならず、運用コストが重いものでした。
また、これらのサーバは基本的に常時起動していなくてはなりません。
例えば季節や曜日に応じてアクセス数が大きく変わるものでは、あまりアクセスがないときにリソースが無駄になってしまいます。
サーバレスにすることで、運用コストを抑えたり、完全な従量課金を実現したりすることが可能になります。
目標
まずはこちらのスライドのような構成で小さく作ります。
ただしJSのフレームワークはVue.jsを使います。
次回から、まずはVue.jsでサンプル的にSPAを作ってみます。
おまけ
理想はこんな感じです。
ここまで立派なものは作れませんが、少しずつ付け加えて良いものにしていきたいです。
参考
- Serverworks | 【3分で読める!】サーバレスアーキテクチャって何?エンジニアが憧れるクラウドを活かしたシステムのご紹介
- kakakakakku blog | AWS をフル活用して「サーバレス」な SPA を実装できる「サーバーレスシングルページアプリケーション」を読んだ
- SSSSLIDE | Serverless FrameworkとVue.jsのSSRでWebサイトを作った話
- mya-ake.com | Angular, React, Vue, Svelte, Riotの個人的な選び方