Cloud Run:为什么我的实例需要大量的内存?
来源:stackoverflow
时间:2024-03-23 11:27:34 157浏览 收藏
在 Google Cloud Run 上运行时,一个 Go 应用程序会因内存不足而返回 HTTP 代码 500。尽管在本地运行时该应用程序仅需 20MB RAM,但在 Cloud Run 上却需要至少 512MB RAM。这可能是由于 Cloud Run 环境中容器文件系统使用内存造成的。
我有一个 golang 进程,可以在 400mb sqlite 文件上运行 sql 查询。
我使用 https://github.com/mattn/go-sqlite3 和连接字符串:
file:mydb.sqlite?mode=ro&_journal=delete
当在我的 docker 开发机器上运行时,它只需要 20mb ram,但在 google run 上,任何小于 512mb 的实例都将返回 http 代码 500,并在日志中显示 内存超出
限制。
docker diff x
显示数据库文件未修改(我认为这会导致 gvisor 将整个二进制 sqlite 数据库文件复制到 ram 来修改它)。
docker镜像是如何构建的
我正在使用源代码将 sqlite db 文件复制到映像中:
from golang:latest ... copy . /go/src/api
我的 golang 文件中有一个全局变量:var db *sqlx.db
这在主 fn 中设置,在 listenandserve
之前:
constr := fmt.sprintf("file:%s?mode=ro&_journal=delete", *filename) dbconn, err := sqlx.open("sqlite3", constr) db = dbconn
我在 http 请求中查询数据库:
err := db.selectv(&outdataset, "select...", arg1, arg2)
为什么这一定是 cloud run 环境的问题
docker stats
在本地运行时永远不会超过 20mb。
将 docker run
限制为 20mb ram 在我的开发机器上也可以正常运行:
docker run \ --memory=20m \ --memory-swap=20m \
cloud run“容器内存分配”指标也远低于 128m:
https://console.cloud.google.com/monitoring/metrics-explorer
谢谢。
解决方案
根据官方文档:
我还建议考虑:
Are your container instances exceeding memory?
您的容器文件系统似乎正在使用内存。
终于介绍完啦!小伙伴们,这篇关于《Cloud Run:为什么我的实例需要大量的内存?》的介绍应该让你收获多多了吧!欢迎大家收藏或分享给更多需要学习的朋友吧~golang学习网公众号也会发布Golang相关知识,快来关注吧!
-
502 收藏
-
502 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
139 收藏
-
204 收藏
-
325 收藏
-
477 收藏
-
486 收藏
-
439 收藏
-
357 收藏
-
352 收藏
-
101 收藏
-
440 收藏
-
212 收藏
-
143 收藏
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 立即学习 542次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 立即学习 508次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 立即学习 497次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 立即学习 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 立即学习 484次学习