Discuz! 论坛使用云数据库可能遭遇随机的“The table XXX is full”异常
来源:互联网 发布:mysql log 文件位置 编辑:程序博客网 时间:2024/05/22 13:07
前言
想必很多人都知道Discuz!这个论坛,通常会有很多人把它部署在云服务器上,数据库也使用的是云数据库,但是工作很久后,数据库的容量会用完,因此报了“The table xxx is full”异常。本文就如何解决这个问题。
一个Discuz! 论坛在腾讯云已经良好工作了很久,不久前突然随机出现以下错误:
从字面意思上看,就是数据表“common_visit”满了写不进去,最可能的就是磁盘满了。不过这个论坛使用的是云数据库CDB,所以也可能是云数据库的容量用完了。登陆上去查一下使用情况:
10G的空间还只用了2.6G,远远没有满呢,那是出了什么问题呢?
其实 Discuz! 论坛多年前设计的时候,把一些临时性的需要频繁读写的数据表设计为了内存表,这样避免在读写这些表的时候会产生磁盘 io 操作,从而提高了系统的性能。这在那个软硬件性能相比今天非常弱的时代无疑是一个巨大的优化。
但是这样需要确保数据库有足够多的内存来创建内存表。其实在现在的云数据库 CDB 中, io 性能瓶颈已经被极大的打开了,内存表起到的优化作用很有限,相反很容易带来内存不足导致的 table is full 问题。
比较容易的解决方案是把满掉的内存表清空,但是这样会带来一些非核心数据的损失,而且治标不治本,智能临时性的缓解问题:
truncate table common_visit;
更好的选择是把内存表变成innoDB表:
alter table common_visit engine=innoDB;
变更后问题迎刃而解。这样只要放弃一点点看不到影响的性能,就可以比较长久的化解这个问题。
如果有时间可以顺手把其他内存表也都变为innoDB,避免在其他表上再次发生类似的悲剧。
文章出自腾讯云技术社区
https://www.qcloud.com/community/article/535182
推荐大家关注腾讯云技术社区微信公众号:QcloudCommunity
- Discuz! 论坛使用云数据库可能遭遇随机的“The table XXX is full”异常
- MYSQL数据库The table is full错误
- The table is full
- MYSQL 执行Insert语句throws "The table 'xxx' is full" 的问题分析及解决办法
- The table is full mysql
- mysql the table is full
- 解决阿里云数据库RDS报错The table '/home/mysql/data3015/tmp/#sql_13975_23' is full
- 解决mysql出现"the table is full"的问题
- mysql出现"the table is full"的问题
- 解决mysql出现"the table is full"的问题
- 解决mysql出现“the table is full”的问题
- MySQL 出现 The table is full 的解决方法
- mysql出现“the table is full”的问题
- 解决InnoDB出现“the table is full”的问题
- The table xxxx is full处理
- mysql The table 'useroperationlog' is full,数据库运行一会就 run gone away
- ecshop session表已经满的解决方法 The table '_sessi**' is full
- The table‘xxxx’is full 设置临时表大小
- IPC、Binder、AIDL与Intent之间区别与联系
- JSP技术模型(三)JSP指令元素
- 初试ActiveX控件
- 输入一个浮点数,打印出相对应的人民币读法的字符串,如:1605.22转换后为:壹仟陆佰零伍元贰角贰分
- Maven 项目启动 Tomcat 时报丢失jar包解决方法
- Discuz! 论坛使用云数据库可能遭遇随机的“The table XXX is full”异常
- 一起来看看protobuf中容易引起bug的一个细节
- strtok和strtok_r函数的使用
- PAT1032 挖掘机技术哪家强(20)
- iOS APP下载安装时,如果出现此时无法下载安装APP的字样时,一些解决思路
- Unity实现按键碰撞4秒后爆炸C#代码
- Android RecyclerView的那些开源LayoutManager
- R语言笔记第二课,对象、因子、数组
- 【源码解析】JDK源码之ArrayList