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

本文主要是介绍【教程】宝塔default.db占用空间几十g解决方法|宝塔占用磁盘空间特别大解决方法|宝塔磁盘被占满怎么清理,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

目录

  • 一、前言
  • 二、排查问题
  • 三、解决方法

一、前言

用过宝塔创建网站,大家应该都非常熟悉,但是用随着用的时间越来越多,宝塔所占用的空间也越来越多,不停的加大数据盘都没有用,我原先买了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。

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

这篇关于【教程】宝塔default.db占用空间几十g解决方法|宝塔占用磁盘空间特别大解决方法|宝塔磁盘被占满怎么清理的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/875222

相关文章

C# 比较两个list 之间元素差异的常用方法

《C#比较两个list之间元素差异的常用方法》:本文主要介绍C#比较两个list之间元素差异,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录1. 使用Except方法2. 使用Except的逆操作3. 使用LINQ的Join,GroupJoin

MySQL查询JSON数组字段包含特定字符串的方法

《MySQL查询JSON数组字段包含特定字符串的方法》在MySQL数据库中,当某个字段存储的是JSON数组,需要查询数组中包含特定字符串的记录时传统的LIKE语句无法直接使用,下面小编就为大家介绍两种... 目录问题背景解决方案对比1. 精确匹配方案(推荐)2. 模糊匹配方案参数化查询示例使用场景建议性能优

关于集合与数组转换实现方法

《关于集合与数组转换实现方法》:本文主要介绍关于集合与数组转换实现方法,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1、Arrays.asList()1.1、方法作用1.2、内部实现1.3、修改元素的影响1.4、注意事项2、list.toArray()2.1、方

Python中注释使用方法举例详解

《Python中注释使用方法举例详解》在Python编程语言中注释是必不可少的一部分,它有助于提高代码的可读性和维护性,:本文主要介绍Python中注释使用方法的相关资料,需要的朋友可以参考下... 目录一、前言二、什么是注释?示例:三、单行注释语法:以 China编程# 开头,后面的内容为注释内容示例:示例:四

mysql表操作与查询功能详解

《mysql表操作与查询功能详解》本文系统讲解MySQL表操作与查询,涵盖创建、修改、复制表语法,基本查询结构及WHERE、GROUPBY等子句,本文结合实例代码给大家介绍的非常详细,感兴趣的朋友跟随... 目录01.表的操作1.1表操作概览1.2创建表1.3修改表1.4复制表02.基本查询操作2.1 SE

MySQL中的锁机制详解之全局锁,表级锁,行级锁

《MySQL中的锁机制详解之全局锁,表级锁,行级锁》MySQL锁机制通过全局、表级、行级锁控制并发,保障数据一致性与隔离性,全局锁适用于全库备份,表级锁适合读多写少场景,行级锁(InnoDB)实现高并... 目录一、锁机制基础:从并发问题到锁分类1.1 并发访问的三大问题1.2 锁的核心作用1.3 锁粒度分

MySQL数据库中ENUM的用法是什么详解

《MySQL数据库中ENUM的用法是什么详解》ENUM是一个字符串对象,用于指定一组预定义的值,并可在创建表时使用,下面:本文主要介绍MySQL数据库中ENUM的用法是什么的相关资料,文中通过代码... 目录mysql 中 ENUM 的用法一、ENUM 的定义与语法二、ENUM 的特点三、ENUM 的用法1

MySQL count()聚合函数详解

《MySQLcount()聚合函数详解》MySQL中的COUNT()函数,它是SQL中最常用的聚合函数之一,用于计算表中符合特定条件的行数,本文给大家介绍MySQLcount()聚合函数,感兴趣的朋... 目录核心功能语法形式重要特性与行为如何选择使用哪种形式?总结深入剖析一下 mysql 中的 COUNT

Redis出现中文乱码的问题及解决

《Redis出现中文乱码的问题及解决》:本文主要介绍Redis出现中文乱码的问题及解决,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1. 问题的产生2China编程. 问题的解决redihttp://www.chinasem.cns数据进制问题的解决中文乱码问题解决总结

一文详解Git中分支本地和远程删除的方法

《一文详解Git中分支本地和远程删除的方法》在使用Git进行版本控制的过程中,我们会创建多个分支来进行不同功能的开发,这就容易涉及到如何正确地删除本地分支和远程分支,下面我们就来看看相关的实现方法吧... 目录技术背景实现步骤删除本地分支删除远程www.chinasem.cn分支同步删除信息到其他机器示例步骤