【教程】宝塔default.db占用空间几十g解决方法|宝塔占用磁盘空间特别大解决方法|宝塔磁盘被占满怎么清理

简介: 在宝塔面板7.9.0中,用户发现数据盘持续占满,通过`folder size`工具发现`BtSoft\panel\data`下的`default.db`和`system.db`文件占用大量空间,尤其是`default.db`。由于这是SQLite数据库文件,用户使用SQLite Developer打开并发现`boce_list`表包含大量访问记录,可能是宝塔面板未定期清理所致。用户直接清空表后,使用`VACUUM`命令整理数据库以回收空间,成功将`default.db`从18G减至3M,解决了磁盘占用问题。

@[TOC]

一、前言

用过宝塔创建网站,大家应该都非常熟悉,但是用随着用的时间越来越多,宝塔所占用的空间也越来越多,不停的加大数据盘都没有用,我原先买了30G够用了,随着时间一长,发现数据盘又满了,不得不又买了20个G扩容,可是过了一段时间又满了。这我就不能忍了。今天来看看到底是怎么一回事。

我用的宝塔面板版本是 7.9.0
c278fd4381608d67f954bd893bf3935e_4a3edca4f6214c8d8df36efd1ffa3f3c.png

二、排查问题

我用folder size 工具 一个个去看到底哪个文件夹占用的空间最大。一开始还以为是日志文件导致的呢,其实并不是。
folder size下载地址:

https://foldersize.sourceforge.net

55667a61fc386e83afaf71aa112c58d9_41884945297943caaead172bb8e8f75c.png

最后发现是 BtSoft\panel\data 这个文件夹下的defalut.db 和 system.db 两个最大,尤其是default.db 占了18个G。(图片这里因为我已经清理了,大家可以看看自己的defalut.db是多大)

在这里插入图片描述
这个defalut.db 文件当然不能随便删掉了,顾名思义,这种db结尾的就是数据库文件了,查了一下,发现宝塔用的是sqlite 数据库,那我们就下一个工具打开看看到底里面有哪些内容,占了我们这么大

三、解决方法

下载并安装SQLite Developer
下载地址:

http://www.sqlitedeveloper.com/zh-hans-download

image.png

下载好后,我们打开SQLite Developer
点击右上角的【数据库】——选择【创建数据库】,点击数据库输入框旁边的文件夹找到 BtSoft\panel\data文件夹下的 defalut.db 。这里不建议直接选中,避免操作失误导致整个db损坏,可以复制一个到其他文件夹,操作完之后覆盖。但是因为我没有多余的空间了,穷啊,又不想再扩容,我就干脆直接操作了,你们可千万不要跟我一样。

在这里插入图片描述
将default.db加入进来后,我们来看一下所有的表,看下是哪个表的数据最多导致的。
最后,我发现是 boce_list这个表数据特别多 优几十万条数据,估计是所有的访问都记录了下来,好方便排查恶意访问数据的。这里估计是宝塔官方的bug,初衷是好意的,方便排查访问记录,但是没有定期清理这张表,导致占用这么大。

在这里插入图片描述

我的操作很粗暴的,于是我就直接清空了表。你们可以适当清理某些数据

但是清空表之后,发现本地的default.db文件还是特别的大,没有变化,那是因为SQLite 数据库在清理表数据后,其占用的磁盘空间可能不会立即减少。SQLite 使用固定大小的页来存储数据。即使你删除了大量的数据,已经分配出去的页可能不会被立即释放回操作系统。SQLite 会保留这些页以便将来重用,从而提高性能

所以那就手动执行整理数据库的命令。
使用 VACUUM 命令来整理数据库并回收空间

VACUUM;

在这里插入图片描述
选中数据库,点开【工具】按钮,点开【SQL编辑器】按钮。
输入 VACUUM 命令,点击【放大镜】按钮执行,等待一下即可释放成功(如图)。

在这里插入图片描述
然后,你们再看下defalut.db 是不是瞬间变小了,数据盘瞬间活了,由18G瞬间变成3M。第一张图就是我清理后的截图,只占用了3000多K,谁能想到刚刚还是18G。

大家可以按照教程操作,成功了记得点赞留言,谢谢

相关文章
|
8月前
|
Oracle 关系型数据库 Linux
解决在linux服务器上部署定时自动查找cpu,内存,磁盘使用量,并将查询结果写入数据库的脚本,只能手动运行实现插库操作
问题描述:将脚本名命名为mortior.sh(以下简称mo),手动执行脚本后查询数据库,表中有相应的信息,放入自动执行队列中,脚本被执行,但是查询数据库,并没有新增数据。
58 0
|
2月前
|
弹性计算 运维 搜索推荐
幻兽帕鲁内存溢出怎么办,一键设置定时重启,修改虚拟内存,定时清理,轻松解决卡顿!再也不怕爆内存了!
幻兽帕鲁的内存溢出问题,玩久了确实会变卡。这里给出三个解决思路:第一种方法是定时进行内存清理(装个软件就可以),网上也有很多教程,我会把下载地址放在文章后面,大家可以去下载。第二种方法是调大虚拟内存,这个可以一键设置。第三种方法是定时重启游戏服务,这个也可以一键设置。这三种方法我下面都会教给大家,可以有效解决内存增长过快的问题,避免游戏卡顿甚至崩溃。
570 3
|
消息中间件 关系型数据库 Shell
记录贴:sentry磁盘占用过大如何清理?
记录贴:sentry磁盘占用过大如何清理?
978 0
|
数据库
19c初始化数据库提示端口1521占用,但查不到占用的程序[DBT-06103]
19c初始化数据库的时候,提示端口占用,但查不到占用的程序。这个问题很诡异,如果按照提示的思路去查,找占用端口的进程,就走入了错误的方向。
115 0
|
存储 缓存 文件存储
「系统」占用太多硬盘空间?试试用这些方法将它找回来
「系统」占用太多硬盘空间?试试用这些方法将它找回来
306 0
|
缓存 关系型数据库 数据库
GitLab内存占用过高的解决方法
GitLab内存占用过的高解决方法: 系统环境:CentOS 7 GitLab版本:12.10.2-ee 服务器配置:2核4G 非转载以实践
9700 0
GitLab内存占用过高的解决方法
|
iOS开发
Mac系统存储空间占用空间过大解决办法
Mac系统存储空间占用空间过大解决办法
799 0
Mac系统存储空间占用空间过大解决办法
|
关系型数据库 MySQL Linux
linux环境下 xampp mysql 启动失败问题排查 日志文件过大占用存储空间导致网站瘫痪
问题现象 网站莫名其妙的连接不上mysql了,导致网站瘫痪;没有改任何程序,怎么回事呢?马上用xshell 和xftp工具连接linux服务器来排查问题 启动xampp mysql /opt/lampp/lampp startmysql 启动xampp mysql ![/opt/lampp/bin/mysql.
2892 0
|
Windows 搜索推荐
Windows10更新后,解决C盘空间占用过大的方法
本人有开启自动更新的习惯,最近几天,极客君的电脑动不动就更新,每次都更新很久,并且更新完之后还要求重启呢!到今天为止,更新总算是消停下来了,打开更新完的系统极客君发现这次更新变化还是挺大的!比如这个个性化设置界面,变化就非常大,我相信经常使用Windows10的小伙伴们一眼都能看出来。
1472 0