せっかくGCP使ってるので、SPAなアプリをGoogle App Engine(GAE)へデプロイしてみました。
Vue.jsの場合、https://hogehogehoge.xxx/index.html
とindex.html
でアクセスするとルーティングが効かないので、GAEの設定でルーティング設定してやる必要がありました。
前提
- GCPのアカウントがあり利用できる
gcloud
コマンドがインストール済み- Vue CLIがインストール済み
環境構築
適当にVue.jsのプロジェクトを作成します。ここではVue CLIを利用して作成しています。
Vue CLI 3
https://cli.vuejs.org/
ソースをアップしているので、よければご参考ください。
https://github.com/kai-kou/vue-js-on-gae
> mkdir 任意のディレクトリ > cd 任意のディレクトリ > vue --version 3.2.1 > vue create app
プロジェクトが作成できたらローカルで確認しておきます。
> cd app > yarn serve
GAEへデプロイ
Vue.jsのプロジェクトをビルドしてGAEへデプロイします。
> yarn build > touch app.yaml
GAEのスタンダード環境へデプロイする際に必要となるapp.yaml
は下記を参考に定義しました。
Google App Engine で静的ウェブサイトをホストする | PHP の App Engine スタンダード環境 | Google Cloud
https://cloud.google.com/appengine/docs/standard/php/getting-started/hosting-a-static-website?hl=ja
app.yaml
でservice
を指定しない場合、default
サービスにデプロイされますので、すでに別で利用している場合、ご注意ください。
handlers
でルーティング設定する感じですね。
app.yaml
runtime: php55 service: サービス名 threadsafe: true handlers: - url: / static_files: dist/index.html upload: dist/index.html - url: /(.*) static_files: dist/\1 upload: dist/(.*)
ではデプロイしてみます。
> gcloud app deploy Services to deploy: descriptor: [任意のディレクトリ/app/app.yaml] source: [任意のディレクトリ/app] target project: [GCPのプロジェクトID] target service: [サービス名] target version: [20181218t121024] target url: [https://[サービス名]-dot-[GCPのプロジェクトID].appspot.com] Do you want to continue (Y/n)? Beginning deployment of service [サービス名]... ╔════════════════════════════════════════════════════════════╗ ╠═ Uploading 3147 files to Google Cloud Storage ═╣ ╚════════════════════════════════════════════════════════════╝ File upload done. ERROR: (gcloud.app.deploy) INVALID_ARGUMENT: This deployment has too many files. New versions are limited to 10000files for this app. - '@type': type.googleapis.com/google.rpc.BadRequest fieldViolations: - description: This deployment has too many files. New versions are limited to 10000 files for this app. field: version.deployment.files[...]
はい。
エラーになりました。ファイル多すぎだそうです。
原因はプロジェクトに含まれるnode_modules
などもアップロードされてしまったからです。app.yaml
に特定のファイルを除外する指定skip_files
を追加します。
app.yamlに関する仕様は下記が詳しかったです。
app.yaml リファレンス | PHP の App Engine スタンダード環境 | Google Cloud
https://cloud.google.com/appengine/docs/standard/php/config/appref?hl=ja
app.yaml
runtime: php55 service: サービス名 threadsafe: true handlers: - url: / static_files: dist/index.html upload: dist/index.html - url: /(.*) static_files: dist/\1 upload: dist/(.*) skip_files: - node_modules/ - public/ - src/ - .browserslistrc - .gitignore - babel.config.js - pakage.json - postcss.config.js - README.md - tsconfig.json - tslint.json - yarn.lock
あらためてデプロイします。
> gcloud app deploy (略) Beginning deployment of service [サービス名]... ╔════════════════════════════════════════════════════════════╗ ╠═ Uploading 66 files to Google Cloud Storage ═╣ ╚════════════════════════════════════════════════════════════╝ File upload done. Updating service [サービス名]...done.
今度はデプロイできました。
ブラウザで確認してみます。
ルーティングも効いています。
やったぜ。
参考
Vue CLI 3
https://cli.vuejs.org/
Google App Engine で静的ウェブサイトをホストする | PHP の App Engine スタンダード環境 | Google Cloud
https://cloud.google.com/appengine/docs/standard/php/getting-started/hosting-a-static-website?hl=ja
app.yaml リファレンス | PHP の App Engine スタンダード環境 | Google Cloud
https://cloud.google.com/appengine/docs/standard/php/config/appref?hl=ja