本教程介绍如何在 Cloud Run 上处理会话。
许多应用需要处理会话以进行身份验证和设定用户偏好设置。
Gorilla Web Toolkit
sessions 软件包附带一个基于文件系统的实现,可实现此功能。但此实现不适用于可以通过多个实例提供的应用,因为各实例之间记录的会话可能不同。gorilla/sessions 软件包还附带一个基于 Cookie 的实现。但此实现需要加密 Cookie 并将整个会话存储在客户端上,而不仅仅是执行加密和存储会话 ID,整个会话对于某些应用而言可能过大。
目标
- 编写应用。
- 在本地运行应用。
- 在 Cloud Run 上部署应用。
费用
在本文档中,您将使用 Cloud de Confiance by S3NS的以下收费组件:
完成本文档中描述的任务后,您可以通过删除所创建的资源来避免继续计费。如需了解详情,请参阅清理。
准备工作
-
In the Cloud de Confiance console, on the project selector page, select or create a Cloud de Confiance project.
Roles required to select or create a project
- Select a project: Selecting a project doesn't require a specific IAM role—you can select any project that you've been granted a role on.
-
Create a project: To create a project, you need the Project Creator role
(
roles/resourcemanager.projectCreator), which contains theresourcemanager.projects.createpermission. Learn how to grant roles.
-
Verify that billing is enabled for your Cloud de Confiance project.
Enable the Firestore API.
Roles required to enable APIs
To enable APIs, you need the Service Usage Admin IAM role (
roles/serviceusage.serviceUsageAdmin), which contains theserviceusage.services.enablepermission. Learn how to grant roles.-
在 Cloud de Confiance 控制台中,通过 Cloud Shell 打开此应用。
利用 Cloud Shell,您可以直接在浏览器中通过命令行访问云端资源。在浏览器中打开 Cloud Shell,然后点击继续下载示例代码并切换到应用目录。
-
在 Cloud Shell 中,配置 gcloud CLI 以使用新的 Cloud de Confiance 项目:
# Configure gcloud for your project gcloud config set project YOUR_PROJECT_ID
设置项目
在终端窗口中,将示例应用代码库克隆到本地机器:
git clone https://github.com/GoogleCloudPlatform/golang-samples.git
转到包含示例代码的目录:
cd golang-samples/getting-started/sessions
了解 Web 应用
此应用为每位用户显示不同语言的问候语。回访用户始终会收到同一种语言的问候语。
您需要先存储会话中当前用户的相关信息,然后应用才能拿存储用户偏好设置。此示例应用使用 Firestore 来存储会话数据。
应用首先导入依赖项,指定用于保存
sessions.Store和 HTML 模板的app类型,并指定问候语列表。接下来,该应用会定义
main函数,以创建新的app实例、注册索引处理程序并启动 HTTP 服务器。newApp函数通过设置projectID和collectionID值来创建app实例,并解析 HTML 模板。索引处理程序获取用户的会话,如果需要的话,可创建一个会话。系统会为新会话分配一种随机语言,此时视图计数为 0。然后,视图计数会加 1,系统会保存会话,HTML 模板会写入响应。
下图说明 Firestore 如何处理 Cloud Run 应用的会话。
删除会话
您可以在 Cloud de Confiance 控制台中删除会话数据,或实施自动删除策略。如果您为会话使用 Memcache 或 Redis 等存储解决方案,系统会自动删除已过期的会话。
在本地运行
在终端窗口中,构建
sessions二进制文件:go build启动 HTTP 服务器:
./sessions查看网络浏览器中的应用:
Cloud Shell
在 Cloud Shell 工具栏中,点击 Web 预览
,然后选择在端口 8080 上预览。本地机器
在浏览器中,转到
http://localhost:8080您会看到五个问候语之一:“Hello World”、“Hallo Welt”、“Hola mundo”、“Salut le Monde”或“Ciao Mondo”。如果您使用其他浏览器或无痕模式打开网页,语言会更改。 您可以在 Cloud de Confiance 控制台中查看和修改会话数据。

要停止 HTTP 服务器,请在终端窗口中按
Control+C。
在 Cloud Run 上部署和运行
您可以使用 Cloud Run 来构建和部署可在负载繁重和具有大量数据的情况下可靠运行的应用。
- 在 Cloud Run 上部署应用:
gcloud run deploy firestore-tutorial-go
--source . --allow-unauthenticated --port=8080
--set-env-vars=GOOGLE_CLOUD_PROJECT=YOUR_PROJECT_ID - 访问此命令返回的网址,以查看会话数据在页面加载之间如何持久存在。
现在,问候语由在 Cloud Run 实例上运行的 Web 服务器提供。
调试应用
如果您无法连接到 Cloud Run 应用,请检查以下内容:
- 检查
gcloud部署命令是否已成功完成,并且未输出任何错误。如果存在错误(例如message=Build failed),请更正这些错误,然后重试部署 Cloud Run 应用。 在 Cloud de Confiance 控制台中,前往 Logs Explorer 页面。
在最近选择的资源下拉列表中,点击 Cloud Run 应用,然后点击所有 module_id。您将看到访问您的应用时的请求列表,如果您未发现请求列表,请确认您是否已从下拉列表中选择所有 module_id。如果您发现 Cloud de Confiance 控制台出现错误消息,请检查应用代码是否与“编写 Web 应用”相关部分中的代码匹配。
确保已启用 Firestore API。
清理
删除项目
- 在 Cloud de Confiance 控制台中,前往管理资源页面。
- 在项目列表中,选择要删除的项目,然后点击删除。
- 在对话框中输入项目 ID,然后点击关闭以删除项目。
删除 Cloud Run 实例
- 在 Cloud de Confiance 控制台中,前往 App Engine 的版本页面。
- 选中要删除的非默认应用版本对应的复选框。
- 如需删除应用版本,请点击删除。
后续步骤
- 试学 Cloud Run functions 教程。
- 详细了解 Cloud Run。
- 试用 Cloud Run,该平台可让您在完全托管式环境或您的自定义 Google Kubernetes Engine 集群中运行无状态容器。