このチュートリアルでは、App Engine でセッションを処理する方法を示します。
多くのアプリには、認証設定とユーザー設定用のセッション処理が必要です。
Gorilla ウェブ ツールキット sessions
パッケージには、この機能を実行するためのファイル システムベースの実装が付属しています。ただし、記録されるセッションがインスタンス間で異なる場合があるため、この実装は複数のインスタンスから提供できるアプリには適していません。gorilla/sessions
パッケージには、Cookie ベースの実装も付属しています。ただし、この実装では、セッション ID だけでなく、Cookie を暗号化してセッション全体をクライアントに保存する必要があるため、一部のアプリでは大きすぎる場合があります。
目標
- アプリを作成する。
- アプリをローカルで実行する。
- App Engine にアプリをデプロイする。
費用
このドキュメントでは、Google Cloud の次の課金対象のコンポーネントを使用します。
料金計算ツールを使うと、予想使用量に基づいて費用の見積もりを生成できます。
このドキュメントに記載されているタスクの完了後、作成したリソースを削除すると、それ以上の請求は発生しません。詳細については、クリーンアップをご覧ください。
始める前に
- Sign in to your Google Cloud account. If you're new to Google Cloud, create an account to evaluate how our products perform in real-world scenarios. New customers also get $300 in free credits to run, test, and deploy workloads.
-
In the Google Cloud console, on the project selector page, select or create a Google Cloud project.
-
Make sure that billing is enabled for your Google Cloud project.
-
Enable the Firestore API.
- Install the Google Cloud CLI.
-
To initialize the gcloud CLI, run the following command:
gcloud init
-
In the Google Cloud console, on the project selector page, select or create a Google Cloud project.
-
Make sure that billing is enabled for your Google Cloud project.
-
Enable the Firestore API.
- Install the Google Cloud CLI.
-
To initialize the gcloud CLI, run the following command:
gcloud init
-
gcloud
コンポーネントを更新します。gcloud components update
- 開発環境を準備します。
プロジェクトの設定
ターミナル ウィンドウで、サンプルアプリ リポジトリのクローンをローカル マシンに作成します。
git clone https://github.com/GoogleCloudPlatform/golang-samples.git
サンプルコードが入っているディレクトリに移動します。
cd golang-samples/getting-started/sessions
ウェブアプリについて理解する
このアプリは、ユーザーごとに異なる言語で挨拶を表示します。リピーターは常に同じ言語で挨拶されます。
アプリでユーザーの設定を保存するには、現在のユーザーに関する情報をセッションに保存する方法が必要です。このサンプルアプリは、Firestore を使用してセッション データを保存します。
gorilla/sessions
と互換性のあるセッション ストア、firestoregorilla
を使用できます。
アプリは、依存関係をインポートし、
sessions.Store
と HTML テンプレートを保持するためのapp
関数を定義して、挨拶の一覧を定義することにより起動します。次に、アプリが
main
関数を定義します。この関数は、新しいapp
インスタンスを作成し、インデックス ハンドラを登録して、HTTP サーバーを起動します。newApp
関数は、firestoregorilla.New
関数を使用してsessions.Store
を初期化することにより、app
インスタンスを作成します。インデックス ハンドラは、ユーザーのセッションを取得し、必要に応じてセッションを作成します。新しいセッションには、ランダムな言語とビューカウント「0」が割り当てられます。次に、ビューカウントが 1 増加し、セッションが保存され、HTML テンプレートにより応答が書き込まれます。
次の図は、Firestore が App Engine アプリ用のセッションを処理する方法を示しています。
セッションの削除
firestoregorilla
は、古いセッションや期限切れのセッションを削除しません。Google Cloud コンソールでセッション データを削除するか、自動削除戦略を実装できます。セッションに、Memcache や Redis などのストレージ ソリューションを使用すると、期限切れのセッションが自動的に削除されます。
ローカルでの実行
ターミナル ウィンドウで、
sessions
バイナリをビルドします。go build
HTTP サーバーを起動します。
./sessions
ウェブブラウザでアプリを表示します。
Cloud Shell
Cloud Shell ツールバーの [ウェブでプレビュー] アイコンをクリックし、[ポート 8080 でプレビュー] を選択します。
ローカルマシン
ブラウザで、
http://localhost:8080
にアクセスします。「Hello World」、「Hallo Welt」、「Hola mundo」、「Salut le Monde」、「Ciao Mondo」の 5 つの挨拶のいずれかが表示されます。別のブラウザまたはシークレット モードでページを開くと、別の言語で表示されます。 セッション データは Google Cloud コンソールで表示して編集できます。
HTTP サーバーを停止するには、ターミナル ウィンドウで
Control+C
を押します。
App Engine でのデプロイと実行
App Engine スタンダード環境を使用すると、高い負荷の下で大量のデータを使用して正常に動作するアプリをビルドしてデプロイできます。
このチュートリアルでは、App Engine スタンダード環境を使用してサーバーをデプロイします。
app.yaml
ファイルには、App Engine スタンダード環境の構成が含まれています。
App Engine にアプリをデプロイします。
gcloud app deploy
ブラウザに次の URL を入力します。
https://PROJECT_ID.REGION_ID.r.appspot.com
以下を置き換えます。
PROJECT_ID
: Google Cloud プロジェクト IDREGION_ID
: App Engine がアプリに割り当てるコード
これで、App Engine インスタンスで実行しているウェブサーバーから挨拶が配信されます。
アプリのデバッグ
App Engine アプリに接続できない場合は、次の点を確認してください。
gcloud
デプロイ コマンドが正常に終了して、エラーを出力しなかったことを確認します。エラー(message=Build failed
など)が発生した場合は、それらを修正してから、もう一度、App Engine アプリのデプロイを試みます。Google Cloud コンソールで、[ログ エクスプローラ] ページに移動します。
[最近選択したリソース] プルダウン リストで、[App Engine アプリケーション] をクリックしてから、[All module_id] をクリックします。アプリにアクセスした以降のリクエストのリストが表示されます。リクエストのリストが表示されない場合は、プルダウン リストで [All module_id ] が選択されていることを確認します。エラー メッセージが Google Cloud コンソールに出力された場合は、アプリのコードがウェブアプリの作成に関するセクション内のコードと一致することを確認します。
Firestore API が有効になっていることを確認します。
クリーンアップ
プロジェクトの削除
- In the Google Cloud console, go to the Manage resources page.
- In the project list, select the project that you want to delete, and then click Delete.
- In the dialog, type the project ID, and then click Shut down to delete the project.
App Engine インスタンスの削除
- In the Google Cloud console, go to the Versions page for App Engine.
- Select the checkbox for the non-default app version that you want to delete.
- アプリのバージョンを削除するには、[ 削除] をクリックします。
次のステップ
- Cloud Run 関数のチュートリアルを試す
- App Engine の詳細を確認する
- Cloud Run を使用してみる(フルマネージド環境や独自の Google Kubernetes Engine クラスタでステートレス コンテナを実行できます)。