云服务器存储空间不足导致的docker image运行失败或Not enough space in /var/cache/apt/archives

最近遇到了两次空间不足导致docker实例下的mongodb运行失败的问题。

排查错误

首先用nettools看下mongodb端口有没有被占用:
sudo apt install net-tools

netstat --all --program | grep '27017'

原因和解决方案

系统日志文件太大

一般情况下日志文件不会很大,多在20M~200M以内。

运行 cd /var/log && ls -lahS 按大小排列一下日志文件,如果发现 var/log/btmp 太大(我的超过了1G)那就是中招了,可能是有人在暴力破解你的登录密码。

这里我使用较为简单的方式,修改掉默认ssh端口22(注意:ftp文件传输协议使用的端口默认也是22)为其他的,例如13202。如果有更好的方法稍后会补充。

先修改下ssh的默认端口,位置在:

nano /etc/ssh/sshd_config

在去VPS(云服务器)的管理面板防火墙删除掉22的入站规则,然后增加端口13202的入站规则:

Docker运行和缓存吃掉了所有剩余空间

  1. Docker自身运行过程中产生大量的build/pull缓存,而linux下安装的非docker-desktop版本(以我的Debian12为例)没有对镜像+缓存大小进行限制。

例如打开Windows版的Docker Desktop你可以看到:

解决方法:

使用docker system prune 手动清除不需要的

然后像docker desktop一样设定存储大小限制。我这里设置为了15G。

修改 sudo nano /etc/docker/daemon.json (没有就新建)。直接粘贴进去如下内容:

json 复制代码
{
  "builder": {
    "gc": {
      "defaultKeepStorage": "20GB",
      "enabled": true
    }
  },
  "experimental": false,
  "registry-mirrors": []
}

使用 sudo systemctl restart docker 重启docker服务即可

相关推荐
艾伦_耶格宇22 分钟前
【ACP】阿里云云计算高级运维工程师--ACP
运维·阿里云·云计算
FrankYoou1 小时前
Jenkins 与 GitLab CI/CD 的核心对比
java·docker
一位摩羯座DBA1 小时前
Redhat&Centos挂载镜像
linux·运维·centos
隆里卡那唔1 小时前
在dify中通过http请求neo4j时为什么需要将localhost变为host.docker.internal
http·docker·neo4j
疯子的模样1 小时前
Docker 安装 Neo4j 保姆级教程
docker·容器·neo4j
计算机毕设定制辅导-无忧学长1 小时前
西门子 PLC 与 Modbus 集成:S7-1500 RTU/TCP 配置指南(一)
服务器·数据库·tcp/ip
cui_win2 小时前
【网络】Linux 内核优化实战 - net.core.flow_limit_table_len
linux·运维·网络
风清再凯2 小时前
自动化工具ansible,以及playbook剧本
运维·自动化·ansible
深圳安锐科技有限公司2 小时前
深圳安锐科技发布国内首款4G 索力仪!让斜拉桥索力自动化监测更精准高效
运维·安全·自动化·自动化监测·人工监测·桥梁监测·索力监测
猫头虎2 小时前
猫头虎 AI工具分享:一个网页抓取、结构化数据提取、网页爬取、浏览器自动化操作工具:Hyperbrowser MCP
运维·人工智能·gpt·开源·自动化·文心一言·ai编程