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

目录

一、前言

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

我用的宝塔面板版本是 7.9.0

二、排查问题

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

folder size下载地址:

bash 复制代码
https://foldersize.sourceforge.net

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

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

三、解决方法

下载并安装SQLite Developer

下载地址:

bash 复制代码
http://www.sqlitedeveloper.com/zh-hans-download

下载好后,我们打开SQLite Developer

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

将default.db加入进来后,我们来看一下所有的表,看下是哪个表的数据最多导致的。

最后,我发现是 boce_list 这个表数据特别多 优几十万条数据,估计是所有的访问都记录了下来,好方便排查恶意访问数据的。这里估计是宝塔官方的bug,初衷是好意的,方便排查访问记录,但是没有定期清理这张表,导致占用这么大。

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

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

所以那就手动执行整理数据库的命令。

使用 VACUUM 命令来整理数据库并回收空间

bash 复制代码
VACUUM;

选中数据库,点开【工具】按钮,点开【SQL编辑器】按钮。

输入 VACUUM 命令,点击【放大镜】按钮执行,等待一下即可释放成功(如图)。

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

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

相关推荐
网管NO.12 分钟前
SQL 企业实战全流程|全覆盖前置基础 + 核心语法(MySQL8.0 可直接运行)
数据库·oracle
头歌实践平台4 分钟前
HBase 完全分布式安装(新)
数据库·分布式·hbase
大尚来也4 分钟前
主键、外键、索引,一篇讲透
java·数据库·oracle
j7~8 分钟前
【MYSQL】表的内外连接--详解(重点)
数据库·mysql·内连接·左外连接·右外连接
147API19 分钟前
Claude Opus 4.8 接口与工程落地分析:长任务调用链应该怎么设计
java·前端·数据库
绝知此事23 分钟前
Redis 从入门到精通:Spring Boot 实战三部曲(一)—— 基础核心与快速上手
数据库·redis·缓存
鸽芷咕25 分钟前
金仓数据库标量子查询消除:一条SQL从32秒优化到24毫秒
数据库·sql
朝阳58130 分钟前
MySQL 主从复制 — 双服务器灾备方案(原生安装)
服务器·数据库·mysql
是狐狸吖31 分钟前
Redis分布式锁进阶第十六篇
数据库·redis·分布式
闪电悠米32 分钟前
黑马点评-优惠券秒杀-04_one_user_one_order
服务器·网络·数据库