Discuz! X2.5/X3-X3.4 InnoDB数据库补丁 beta1.0.8 【2017.8.1更新】
<font size="3"><font color="#ff0000"><strong>2017.8.1更新</strong></font></font><br /><font size="3"><font color="#ff0000"><strong>修正写死mysql_query的问题,兼容mysqli</strong></font></font><br /><font size="3"><font color="#ff0000"><strong><br />2013.10.8更新</strong></font></font><br /><font size="3"><font color="#ff0000"><strong>修正启用主从时可能出现的数据库错误页面</strong></font></font><br /><font size="3"><font color="#ff0000"><strong><br />2013.9.26更新</strong></font></font><br /><font size="3"><font color="#ff0000"><strong>修正bin脚本在关闭论坛或论坛某些设置的情况下不执行而输出html的问题</strong></font></font><br /><font size="3"><font color="#ff0000"><strong><br />2013.9.24升级X3.1请参考最下方升级指南。</strong></font></font><br /><font size="3"><font color="#ff0000"><strong><br />2013.9.12更新</strong></font></font><br /><font size="3"><font color="#ff0000"><strong>修正一个逻辑错误,该错误会导致部分情况下缓存不生效,而导致可能出现的发帖卡顿,建议更新。</strong></font></font><br /><font size="3"><font color="#ff0000"><strong><br />2013.8.30更新</strong></font></font><br /><font size="3"><font color="#ff0000"><strong>修正删帖子后形成一个内容为del_post的空帖子,只有更新内存缓存才会消失的bug</strong></font></font><br /><font size="3"><font color="#ff0000"><strong><br />2013.8.23更新</strong></font></font><br /><font size="3"><font color="#ff0000"><strong>修正一个部分服务器上可能遇到的脚本意外中断问题</strong></font></font><br /><font size="3"><font color="#ff0000"><strong><br />2013.8.13更新</strong></font></font><br /><font size="3"><font color="#ff0000"><strong>修正bin执行脚本log日志累增不清零</strong></font></font><br /><font size="3"><font color="#ff0000"><strong>修正脚本异常退出</strong></font></font><br /><font size="3"><font color="#ff0000"><strong>本脚本分为两部分,第一部分是修改post表结构,第二部分为转换表为INNODB引擎</strong></font></font><br /><font size="3"><font color="#ff0000"><strong>当第一部分出现异常时,脚本会退出并提示重试。这时需要重新执行脚本。</strong></font></font><br /><font size="3"><font color="#ff0000"><strong>当第二部分异常时,脚本仍将执行整个库,并将转换失败的表写到log日志中。</strong></font></font><br /><font size="3"><font color="#ff0000"><strong>这时可以选择按照log中的表名手动转,或者重新执行脚本(可能耗时会多些)</strong></font></font><br /><font size="3"><font color="#ff0000"><strong><br />2013.8.9更新</strong></font></font><br /><font size="3"><font color="#ff0000"><strong>修正了昨天压缩包里一个遗漏,该问题会导致复杂条件的语句失效</strong></font></font><br /><font size="3"><font color="#ff0000"><strong><br />2013.8.8更新</strong></font></font><br /><font size="3"><font color="#ff0000"><strong>修正一个可能导致后台页面管理错误的问题</strong></font></font><br /><font size="3"><font size="3"><br /></font><br />MySQL InnoDB 引擎相比我们论坛默认的 MyISAM 引擎在写性能上有很大提升。</font><font size="3">InnoDB 支持行锁(更准确的说是索引锁)而 MyISAM 只能是表锁。使得 InnoDB 在高并发环境中有更好的表现。 </font><br /><br /><font size="3">在 Discuz! X2 或者更早的版本,有站长手动把数据库引擎转为 InnoDB , 来避免论坛发帖高峰时期带来的卡顿,</font><br /><font size="3">但是 Discuz! X2.5 以及 Discuz! X3版本,由于 post 表使用了联合自增主键,而 InnoDB 不支持这个特性,而无法手动把数据库引擎改为 InnoDB 。</font><br /><font size="3"><br /></font><br /><font size="3">考虑到大型站点站长们的这个需求后,我们发布了</font><font size="3">在大型论坛测试过的第一个Discuz! X2.5 / X3 InnoDB 补丁测试版。</font><br /><br /><font size="3"><font color="#ff0000"><strong>基本原理:</strong></font></font><br /><font size="3">1,去掉 post 表 position 字段的自增属性。</font><br /><font size="3">2,利用内存缓存来记录每个帖子的当前最大楼层数,并在发帖请求过来时依次分发并自增楼层号。</font><br /><font size="3">3,由于内存缓存速度极快当多个发帖请求过来后能快速自增并分配楼层号,每条插入语句都能快速领取到唯一楼层号。</font><br /><font size="3">4,内建了错误修复机制避免内存失效或者统计错误时自动修复。</font><br /><font size="3">5,取消了 count(*) 语句,改为读取模糊值。</font><br /><br /><font size="3"><font color="#ff0000"><strong>适应场景:</strong></font></font><br /><font size="3">发帖比较频繁,适应于会员热衷于交流场景,日发帖一般在数万贴每日的。</font><br /><br /><font size="3"><font color="#ff0000"><strong>服务器要求:</strong></font></font><br /><font size="3">1,独立服务器,或能执行命令行(命令行避免超时)</font><br /><font size="3">2,启用了内存缓存(建议为 memcache或redis )</font><br /><br /><font size="3"><font color="#ff0000"><strong>操作步骤:</strong></font></font><br /><font size="3">使用方法:<br />1,请到 https://www.dismall.com/thread-12045-1-1.html 下载最新对应版本的框架,里面包含了一个文件class_core.php,直接覆盖即可。<br />2,关闭论坛,避免有发帖操作。对数据库全库进行备份。<br />3,确认论坛有开启内存缓存的某一个。<br />4,在命令行下切换到extend/bin目录下执行 bin_innodb_upgrade.php,一般命令如下:<br />切换到该目录下执行<br />~$php bin_innodb_upgrade.php<br />耐心等待执行完毕,如果显示其中一些任务失败了,则需要到目录下找log文件,对转换失败的表手工进行转 innodb 。</font><font size="3">(对于数据库超大需要转换很久的情况,可以采用下面的命令:</font>nohup php bin_innodb_upgrade.php > innodblog 2> innodberror &<br /> ,这样可以关掉客户端而让其在后台执行,执行的即时情况可以到innodblog里面查看<font size="3">)<br />6,删除 innodb_grade.php 和 log 文件(如果有的话),去论坛发帖测试无误后,开放论坛。<br /></font><br /><br /><font size="3"><font color="#ff0000"><strong>恢复:</strong></font></font><br /><font size="3">如果测试后不想使用了,可以按照如下两个步骤操作:</font><br /><font size="3">1,所有表换回MyISAM,恢复 post 表 position 的自增属性。</font><br /><br /><font size="3"><font color="#ff0000"><strong>问题:</strong></font></font><br /><font size="3">使用后出现任何问题都可以到BUG区发帖反馈http://www.discuz.net/forum-70-1.html。</font><br /><font size="3">我们建议大家先在测试论坛上使用无误后再部署到正式论坛。</font><br /><font size="3">如果有新版或者补丁出现,会持续在本帖更新,建议大家关注此贴。</font><br /><br /><strong><font size="3"><font color="red">已知注意事项:</font></font></strong><br />1, MySQL 5.6版本的 index_condition_pushdown 参数请关闭,在帖子倒序显示的时候会引起严重慢查询。<br />2, 因为全表统计 count(*) 改为了读取模糊值,所以有少部分的统计数据最大会有10%左右的偏差。<br />3, 没有一定技术能力,平时服务器运行良好的网站,应继续使用默认的 MyISAM 版本,Innodb 在使用和维护上都有更高的要求。<br />4,在执行脚本的时候一定要保证内存足够,否则很容易造成各种不成功的问题。<br /><br /><font size="3"><font color="#ff0000"><strong>下载:</strong></font></font><br /><ignore_js_op><span style="white-space: nowrap" id="attach_14661" onmouseover="showMenu({'ctrlid':this.id,'pos':'12'})">【20170801】upload_innodb1.0.8_x3.x-x25.zip<em class="xg1">(6.32 KB, 下载次数: 407)</em></span>2022-4-20 15:18 上传点击文件名下载附件</ignore_js_op><br /><br /><strong><font size="3"><font color="#ff0000">X2.5/X3升级到X3.1:</font></font></strong><br />1,按照官方升级指南,在执行完第四步之后,把这个附件解压后把sql文件上传到install/data目录下,<ignore_js_op><span style="white-space: nowrap" id="attach_14660" onmouseover="showMenu({'ctrlid':this.id,'pos':'12'})">install_dev.zip<em class="xg1">(16.06 KB, 下载次数: 362)</em></span>2022-4-20 15:18 上传点击文件名下载附件</ignore_js_op>,然后再执行update脚本。<br />2,确保安装了最新框架,确保原始的innodb扩展文件都存在,确保至少存在一个内存缓存正常工作。<br />3,发帖测试无误后开放。<br /><br /><br /><br /><br />ff0000<em>, </em>更新<em>, </em>执行<em>, </em>论坛
頁:
[1]