前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Discuz! 论坛使用云数据库可能遭遇随机的“The table XXX is full”异常

Discuz! 论坛使用云数据库可能遭遇随机的“The table XXX is full”异常

原创
作者头像
黄希彤
修改2017-08-03 16:18:44
2.4K0
修改2017-08-03 16:18:44
举报
文章被收录于专栏:黄希彤的专栏黄希彤的专栏

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

[1492010797786_8959_1492010798424.png]
[1492010797786_8959_1492010798424.png]

从字面意思上看,就是数据表“common_visit”满了写不进去,最可能的就是磁盘满了。不过这个论坛使用的是云数据库CDB,所以也可能是云数据库的容量用完了。登陆上去查一下使用情况:

[1492011080420_8033_1492011080866.png]
[1492011080420_8033_1492011080866.png]

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

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

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

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

truncate table common_visit;

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

alter table common_visit engine=innoDB;

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

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

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
相关产品与服务
数据库
云数据库为企业提供了完善的关系型数据库、非关系型数据库、分析型数据库和数据库生态工具。您可以通过产品选择和组合搭建,轻松实现高可靠、高可用性、高性能等数据库需求。云数据库服务也可大幅减少您的运维工作量,更专注于业务发展,让企业一站式享受数据上云及分布式架构的技术红利!
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
http://www.vxiaotou.com