云服务器存储空间不足导致的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 分钟前
Nagios Core + 插件 + Web 界面
运维
<但凡.26 分钟前
Linux修炼:基础IO(二)
linux·运维·服务器·1024程序员节
wodongx12335 分钟前
从一开始部署Android项目Sonarqube的自动化扫码+通知+增量扫描功能(Win环境、Docker,基于Jenkins)
运维·docker·jenkins·1024程序员节
小志biubiu1 小时前
linux_缓冲区及简单libc库【Ubuntu】
linux·运维·服务器·c语言·学习·ubuntu·c
java_logo2 小时前
Docker 部署 Elasticsearch 全流程手册
大数据·运维·mongodb·elasticsearch·docker·容器
若尘拂风2 小时前
FreeSWITCH配置文件解析(11) 模块配置文件(modules.conf)
服务器·tcp/ip·udp·freeswitch
TG_yunshuguoji2 小时前
亚马逊云渠道商:AWS实例自动替换策略在哪里设置?
运维·服务器·云计算·aws
Stay Passion2 小时前
Docker 组件:Docker Swarm
运维·docker·容器
路過的好心人2 小时前
Docker + Rabbitmq 集群部署
docker·容器·rabbitmq
极客范儿3 小时前
新华三H3CNE网络工程师认证—STP状态机与收敛过程
服务器·网络·stp·1024程序员节