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

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

时间:2024-04-03 18:32:28浏览次数:13  
标签:宝塔 SQLite 占用 db defalut 磁盘空间 数据库

目录

一、前言

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

我用的宝塔面板版本是 7.9.0
在这里插入图片描述

二、排查问题

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

https://foldersize.sourceforge.net

在这里插入图片描述

最后发现是 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

在这里插入图片描述

下载好后,我们打开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。

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

标签:宝塔,SQLite,占用,db,defalut,磁盘空间,数据库
From: https://blog.csdn.net/qq_27471405/article/details/137341443

相关文章

  • 如何查看KingbaseES数据库占用操作系统内存情况
    当遇到数据库内存告警,并且操作系统内存使用不足,需要分析内存占用的方法。KingbaseES数据库使用操作系统缓存机制,大量的内存很可能被BUFFER/CACHE占用了。从free命令可以看到总共有2.5G多内存,使用了291MB,free剩下1.7GB多,BUFF/CACHE占了474MB。available有1.3GB多,当前这台数据库服......
  • OpenMLDB vs Redis 内存占用量测试报告
    1.背景OpenMLDB是一款开源的高性能全内存SQL数据库,在时序数据存储、实时特征计算等方面都有很多创新和优化。Redis是业界最流行的内存存储数据库,广泛应用于缓存等高性能在线场景。虽然二者应用场景不尽相同,但作为都是使用内存作为存储介质的数据库,希望通过对相同数据行数下......
  • 初始化kubeadm init失败,再次初始化时显示6443、10259、10257、10250、2379、2380被占
    第一次使用kubeadminit初始化时,因kubelet.service和和kubelet未启动等部分原因导致初始化失败,当再次初始化时显示6443、10259、10257、10250、2379、2380这几个端口被占用,一个个使用sudolsof-i:port查看太麻烦,直接使用kubeadmreset将当前节点恢复为未安装Kubernetes的状......
  • 端口被占用,去终止它吧
    1.打开window+r打开cmd2.netstat-ano|findstr[端口号]//说明:netstat-ano|findstr用于查找进程//例如8558端口被占用执行netstat-ano|findstr85583.taskkill/F/PID[PID]//说明:taskkill/F/PID用于`强制终止`指定PID的进程/......
  • chrome占用高cpu的原因 排查大致思路
    设置-更多工具-任务管理器发现是某个b站标签页占用高然后到这个标签页f12开启devtool到performance录制性能分析几秒然后就会发现是https://s1.hdslb.com/bfs/static/pcdn-seeder/reward-seeder-1.2.0.min.js 如果不是某个标签页cpu占用高,而是比如说主进程,devtool就不能......
  • 计算linux磁盘空间
     可以准确获取某个挂载点的硬盘空间,已使用空间。现在问题就出在挂载点的判断和类型过滤上面。 #include<iostream>#include<fstream>#include<sstream>#include<vector>#include<string>#include<sys/statvfs.h>#include<map>structDISK_......
  • 在Linux中,如何查找系统中占用CPU最高的进程?
    在Linux系统中,查找占用CPU最高的进程通常有以下几种方法:1.使用top命令top命令提供了一个实时的、动态刷新的系统资源使用情况视图,其中包括CPU使用率最高的进程。top运行后,屏幕顶部会显示系统整体CPU使用情况,下方则列出各个正在运行的进程及其资源占用情况。默认情况下,进程列......
  • 直播平台制作,优化内存占用不妨试试轻量级数据架构
    直播平台制作,优化内存占用不妨试试轻量级数据架构使用轻量级数据结构在直播平台制作中选择数据结构时,考虑使用轻量级的数据结构,如ArrayList替代Vector,以及StringBuilder替代String拼接。能够在保证功能的前提下,减小内存占用。以下是一些使用轻量级数据结构的方法:1、使用......
  • 直播软件开发,利用对象池实现内存占用优化
    直播软件开发,利用对象池实现内存占用优化对象池是一种重复使用对象的机制,而不是频繁地创建和销毁对象。通过对象池,可以避免创建大量的临时对象,减小对象数量,从而减少直播软件开发中内存占用和垃圾回收的压力。importjava.util.concurrent.ArrayBlockingQueue;importjava.ut......
  • 【GitLab】Ubuntu使用宝塔安装GitLab最新社区版
    首先在Ubuntu安装宝塔面板在官网可以找到脚本一键安装安装GitLab社区版然后在宝塔面板的“软件商店”里面找到GitLab最新社区版12.8.1一键安装安装过程中可能出现以下问题:1.卡在ruby_block[waitforlogrotateservicesocket]actionrun解决办法:在Ubuntu终端中运行......