立即注册 找回密码

QQ登录

只需一步,快速开始

豆包只能上面
查看: 14|回复: 0

[坏境搭建教程] Discuz! 论坛云数据库出现的“The table XXX is full”“common_visit异常

[复制链接]

85

主题

0

回帖

1351

积分

管理员

Rank: 9Rank: 9Rank: 9

积分
1351
发表于 昨天 19:11 | 显示全部楼层 |阅读模式
道勤网-数据www.daoqin.net

亲注册登录道勤网-可以查看更多帖子内容哦!(包涵精彩图片、文字详情等)请您及时注册登录-www.daoqin.net

您需要 登录 才可以下载或查看,没有账号?立即注册

x

想必很多人都知道discuz!这个论坛,通常会有很多人把它部署在云服务器上,数据库也使用的是云数据库,但是工作很久后,数据库的容量会用完,因此报了“The table xxx is full”异常。本文就如何解决这个问题。

一个Discuz! 论坛在腾讯云已经良好工作了很久,不久前突然随机出现以下错误:

1011.jpg

从字面意思上看,就是数据表“common_visit”满了写不进去,最可能的就是磁盘满了。common_visit 是 Discuz! 论坛系统 中的数据表,用于记录用户访问日志。该表因设计为内存表(Memory Table),在云数据库环境中可能出现“The table XXX is full”错误,主要原因是云数据库的内存资源有限

不过这个论坛使用的是云数据库CDB所以也可能是云数据库的容量用完了。登陆上去查一下使用情况:

066.jpg

0G的空间还只用了2.6G,远远没有满呢,那是出了什么问题呢?

其实 Discuz! 论坛多年前设计的时候,把一些临时性的需要频繁读写的数据表设计为了内存表,这样避免在读写这些表的时候会产生磁盘 io 操作,从而提高了系统的性能。这在那个软硬件性能相比今天非常弱的时代无疑是一个巨大的优化。

但是这样需要确保数据库有足够多的内存来创建内存表。其实在现在的云数据库 CDB 中, io 性能瓶颈已经被极大的打开了,内存表起到的优化作用很有限,相反很容易带来内存不足导致的 table is full 问题。

比较容易的解决方案是把满掉的内存表清空,但是这样会带来一些非核心数据的损失,而且治标不治本,智能临时性的缓解问题:

  1. truncate table common_visit;
复制代码

更好的选择是把内存表变成innoDB表:

  1. alter table common_visit engine=innoDB;
复制代码


变更后问题迎刃而解。这样只要放弃一点点看不到影响的性能,就可以比较长久的化解这个问题。

如果有时间可以顺手把其他内存表也都变为innoDB,避免在其他表上再次发生类似的悲剧。





道勤主机提供365天*24小时全年全天无休、实时在线、零等待的售后技术支持。竭力为您免费处理您在使用道勤主机过程中所遇到的一切问题! 如果您是道勤主机用户,那么您可以通过QQ【792472177】、售后QQ【59133755】、旺旺【诠释意念】、微信:q792472177免费电话、后台提交工单这些方式联系道勤主机客服! 如果您不是我们的客户也没问题,点击页面最右边的企业QQ在线咨询图标联系我们并购买后,我们为您免费进行无缝搬家服务,让您享受网站零访问延迟的迁移到道勤主机的服务!
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

关闭

道勤网- 推荐内容!上一条 /2 下一条

!jz_fbzt! !jz_sgzt! !jz_xgzt! 快速回复 !jz_fhlb! !jz_lxwm! !jz_gfqqq!

关于我们|手机版|小黑屋|地图|【道勤网】-www.daoqin.net 软件视频自学教程|免费教程|自学电脑|3D教程|平面教程|影视动画教程|办公教程|机械设计教程|网站设计教程 ( 皖ICP备15000319号-1 )

GMT+8, 2025-7-10 06:15

Powered by DaoQin! X3.4 © 2016-2063 Dao Qin & 道勤科技

快速回复 返回顶部 返回列表