解决多个WordPress站点使用Memcached和Redis缓存插件数据冲突的方法及详细步骤
前言
前不久我使用了Memcached和redis对Wordpress进行了加速,同时开启了PHP加速脚本,网站的速度一下子就上去了,但是最近又发现了其他的一些问题,就是在同一服务器上多个站点使用Memcached和redis冲突的问题,这样速度就慢了,甚至可能出现错误。
原因分析
这是因为 object-cache.php
是使用 WordPress 的表前缀($table_prefix
)来区分不同站点在内存中的缓存的。如果你在同个服务器多个 WordPress 网站的表前缀都相同,都是默认的 wp_
,那么 object-cache.php
就无法区分是哪个站点了。那么怎么解决呢?
Memcached处理步骤
知道了问题,那么就非常好解决,有两个解决方法:
1. 修改表前缀,让不同的 WordPress 博客使用不同的表前缀。但是一般修改表前缀都涉及到数据库,很多小白都不会操作,我也不会,
2. 如果修改表前缀不方便,我还提供了 WP_CACHE_KEY_SALT
这个缓存 key 盐值的常量,你只需要在不同站点的 wp-config.php 文件定义不同的 WP_CACHE_KEY_SALT
值即可。
比如两个站点分别定义为:
define('WP_CACHE_KEY_SALT', 'site1');
define('WP_CACHE_KEY_SALT', 'site2');
Memcached实操
分别在两个网站的wp-config.php中加入用CACHE_KAY把两个网站区分开。
define('WP_CACHE_KEY_SALT', 'www.nuoyo.cn');
define('WP_CACHE_KEY_SALT', 'zy.nuoyo.cn');
记得保存wp-config.php文件,然后重启下或者释放缓存一下就可以了!
同时使用Redis
服务器安装Redis扩展后,默认创建16个Redis数据库(序号0-15),WordPress插件Redis Object Cache中没有选择指定数据库序号的选项,只能使用Redis的第一个库。
一台服务器如果有多个WordPress站点并且都安装使用Redis对象缓存插件,就会导致其中一个站点的数据是另一个站点的数据。
Reids实操
打开第二个站点的/wp-content/plugins/redis-cache/includes/object-cache.php
搜索:database
,大概在第629行,把“0”改成1-15的任意数。
同样地,修改完重启Redis即可
如果Redis数据库中已有冲突数据无法进入后台。
可以进入服务器目录,把wp-content
下面的这个缓存文件object-cache.php
删掉,就可以恢复访问后台了。