·设为首页收藏本站📧邮箱修改🎁免费下载专区🔐设置/修改密码👽群雄群聊
返回列表 发布新帖

Discuz!使用Redis缓存多站点分库和避免清空所有的数据教程!

635 0
发表于 2021-3-11 10:13:33 | 显示全部楼层 阅读模式

马上注册,免费下载更多dz插件网资源。

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

×
Discuz!内存级缓存介绍

缓存层的引入是为了解决MYSQL自身对高并发处理的性能瓶颈,目前产品缓存层采用主流的Key-Value对形式,内存级的缓存产品很多,支持的内存优化接口有 Memcache、eAccelerator、Alternative PHP Cache(APC)、Xcache、Redis 五种,优化系统将会依据当前服务器环境依次选用接口,单服务器环境中推荐使用APC,多服务器环境中推荐使用Redis或Memcache。

现存问题说明

有不少站长在一个服务器上安装多个站点,且同时使用Redis作为缓存过程中发现,当使用后台->全局->性能优化->内存优化->内存清理,会把redis缓存的全部站点的内容都清空。
Discuz!使用Redis缓存多站点分库和避免清空所有的数据教程! 使用,redis,缓存,站点,分库

改进方案

具体实现如下:


1、修改文件config\config_global.php

  1. $_config['memory']['redis']['serializer'] = 1;
复制代码

下方增加一行
  1. $_config['memory']['redis']['db'] = 1;//这里可以填写0到15的数字,每个站点使用不同的,redis默认是16个库,也可以增加库2、修改文件source\class\memory\memory_driver_redis.php在 [code]@$this->obj->setOption(Redis::OPT_SERIALIZER, $config['serializer']);
复制代码

下方加上一行
  1. $this->select($config['db']);
复制代码

3、将flushAll改成flushdb避免后台清理影响全部站点;
  1. function clear() {return $this->obj->flushAll();}
复制代码

改成
  1. function clear() {return $this->obj->flushdb();}
复制代码
我要说一句 收起回复
一花一世界,一叶一追寻。一曲一场叹,一生为一人。

回复

 懒得打字嘛,点击右侧快捷回复【查看最新发布】   【应用商城享更多资源】
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

投诉/建议联系

discuzaddons@vip.qq.com

未经授权禁止转载,复制和建立镜像,
如有违反,按照公告处理!!!
  • 联系QQ客服
  • 添加微信客服

联系DZ插件网微信客服|最近更新|Archiver|手机版|小黑屋|DZ插件网! ( 鄂ICP备20010621号-1 )|网站地图

您的IP:52.14.224.197,42.81.98.55,GMT+8, 2024-5-3 20:47 , Processed in 0.166745 second(s), 69 queries , Gzip On, Redis On.

Based on Discuz! W1.0 Licensed

© 2001-2024 Discuz! Team.

关灯 在本版发帖
扫一扫添加微信客服
QQ客服返回顶部
快速回复 返回顶部 返回列表