由于 docker 占用空间过多导致博客崩溃 (一)

昨天博客写笔记时突然崩掉,没法愉快的玩耍了。。

排错

按照步骤来,连上服务器看看服务状态

  1. 检查服务

docker ps

[root@izj6c11y5fbhepw9woftklz java]# docker ps  
CONTAINER ID        IMAGE               COMMAND                  CREATED             STATUS              PORTS                    NAMES  
f2380e20b853        b3log/solo          "java -cp lib/*:. or…"   4 months ago        Up About an hour                             solo  
9da3e37f7416        nginx               "nginx -g 'daemon of…"   6 months ago        Up About an hour    0.0.0.0:80->80/tcp       nginx

发现服务还在,于是认为是自己刚刚可能搞了啥子骚操作,把博客整出 bug 了。所以为了偷懒,直接更新下容器 docker pull b3log/solo,然后重新 run 个容器出来。然而问题依旧!

  1. 查看日志

突然想起来我数据库好像也是用 docker 部署的,刚刚 docker ps 似乎没有看到 MySQL 的影子!docker ps -a 确认一下,果然发现 MySQL 死掉了。
由于我有三四台服务器,我有点忘记了这个博客是不是用的这个库,所以执行 docker logs --tail 50 solo 发现确实报错:

[INFO ]-[2020-05-18 22:40:22]-[org.b3log.solo.Server:216]: Solo is booting [ver=3.8.0, os=Linux, isDocker=true, inJar=false, luteAvailable=false, pid=1, runtimeDatabase=MYSQL, runtimeMode=PRODUCTION, jdbc.username=root, jdbc.URL=jdbc:mysql://127.0.0.1:3306/solo?useUnicode=yes&characterEncoding=UTF-8&useSSL=false&serverTimezone=UTC]
[ERROR]-[2020-05-18 22:40:24]-[com.zaxxer.hikari.pool.HikariPool:587]: HikariPool-1 - Exception during pool initialization.
com.mysql.cj.jdbc.exceptions.CommunicationsException: Communications link failure

于是重启 MySQL:docker start mysql
docker 报错:No space left on device

  1. 清理空间

额 ,好吧!空间不够!df -h 查看发现根目录已经 100% 了

[root@izj6c11y5fbhepw9woftklz java]# df -h
Filesystem      Size  Used Avail Use% Mounted on
devtmpfs        909M     0  909M   0% /dev
tmpfs           919M   16K  919M   1% /dev/shm
tmpfs           919M   83M  837M   9% /run
tmpfs           919M     0  919M   0% /sys/fs/cgroup
/dev/vda1        25G   25G  	0  	100% /

使用下面 两个命令,从根目录开始检查,删除不必要的文件:

cd /
du --max-depth=1 -h 

最后发现 docker 占用空间异常的大,原来是我在里面还部署了 MQ 、ZK、Redis 等一堆东西用来学习,忍痛割爱只有把这些清理了,移到另一个服务器上学习了。

docker system df
docker stop +要删除的容器
docker rm $(docker ps -a -q)
docker system prune

docker rm $(docker ps -a -q) 是安全的,因为没有加 -f 的时候,正在运行的容器无法被删除。
docker system prune 命令可以用于清理磁盘,删除关闭的容器、无用的数据卷和网络,以及 dangling 镜像(即无 tag 的镜像)。docker system prune -a 命令清理得更加彻底,可以将没有容器使用 Docker 镜像都删掉。

  1. 重启服务

在清理足够空间后,开始重启服务。

init 6 #重启
docker start mysql
docker start solo
docker start nginx

在浏览器输入 blog.caiqz.cn,然而!404 都没有了,网站直接没有任何响应了!未完待遇。。。。

  • Docker

    Docker 是一个开源的应用容器引擎,让开发者可以打包他们的应用以及依赖包到一个可移植的容器中,然后发布到任何流行的操作系统上。容器完全使用沙箱机制,几乎没有性能开销,可以很容易地在机器和数据中心中运行。

    330 引用 • 787 回帖 • 491 关注
  • NGINX

    NGINX 是一个高性能的 HTTP 和反向代理服务器,也是一个 IMAP/POP3/SMTP 代理服务器。 NGINX 是由 Igor Sysoev 为俄罗斯访问量第二的 Rambler.ru 站点开发的,第一个公开版本 0.1.0 发布于 2004 年 10 月 4 日。

    255 引用 • 479 回帖 • 547 关注
  • 宝塔

    天王盖地虎,宝塔镇河妖。

    14 引用 • 61 回帖
  • 宕机

    宕机,多指一些网站、游戏、网络应用等服务器一种区别于正常运行的状态,也叫“Down 机”、“当机”或“死机”。宕机状态不仅仅是指服务器“挂掉了”、“死机了”状态,也包括服务器假死、停用、关闭等一些原因而导致出现的不能够正常运行的状态。

    12 引用 • 72 回帖 • 2 关注
回帖
请输入回帖内容...