查看: 411|回复: 2

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

[复制链接]

3992

主题

353

回帖

4482

积分

论坛元老

积分
4482
发表于 2023-2-9 04:19:06 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。

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

x
Discuz!内存级缓存介绍

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

现存问题说明

有不少站长在一个服务器上安装多个站点,且同时使用Redis作为缓存过程中发现,当使用后台->全局->性能优化->内存优化->内存清理,会把redis缓存的全部站点的内容都清空。
d1.jpg

改进方案

具体实现如下:


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();}
复制代码

免责声明

1.本网站所收集的部分公开资料来源于互联网,转载的目的在于传递更多信息及用于网络分享,并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。
2.如果您发现网站上有侵犯您的知识产权的作品,请与我们取得联系,我们会及时修改或删除。

上一篇:DIY调用主题标签TAG修改方法
下一篇:删除版块名称后的主题数字

回复

使用道具 举报

159

主题

389

回帖

665

积分

高级会员

积分
665
发表于 2023-2-9 04:19:52 | 显示全部楼层
感谢分享!太实用了!
这么好的教程,现在还没人评论,抢沙发{:2_25:}
回复 支持 反对

使用道具 举报

156

主题

357

回帖

626

积分

高级会员

积分
626
发表于 2023-2-9 04:20:25 | 显示全部楼层
经过对比发现 X3.5已经默认是这样的设置
  1. $_config['memory']['prefix'] = 'p1oXuh_';$_config['memory']['redis']['server'] = '127.0.0.1';$_config['memory']['redis']['port'] = 6379;$_config['memory']['redis']['pconnect'] = 1;$_config['memory']['redis']['timeout'] = 0;$_config['memory']['redis']['requirepass'] = '';$_config['memory']['redis']['db'] = 0;
复制代码
source\class\memory\memory_driver_redis.php

已经默认
  1. function clear() {                return $this->obj->flushDb();        }
复制代码
指定数据库
  1.     @$this->obj->setOption(Redis::OPT_SERIALIZER, Redis::SERIALIZER_NONE);                                $this->select(isset($config['db']) ? $config['db'] : 0);
复制代码
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

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