登录
首页 >  Golang >  Go问答

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

谢谢。


解决方案


根据官方文档:

Configuring Memory Limits

我还建议考虑:

Are your container instances exceeding memory?

您的容器文件系统似乎正在使用内存。

终于介绍完啦!小伙伴们,这篇关于《Cloud Run:为什么我的实例需要大量的内存?》的介绍应该让你收获多多了吧!欢迎大家收藏或分享给更多需要学习的朋友吧~golang学习网公众号也会发布Golang相关知识,快来关注吧!

声明:本文转载于:stackoverflow 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>