这里有最新的使用文档和教程
WordPress:Memcached 内存缓存优化 ,加速WordPress 后台媒体库加载
WordPress网站媒体库的图片随着文章的增长,会越来越多,有时候不断的去翻几个月前的图片进行引用,发现显示特别慢,原来这个内存缓存并没有缓存媒体库月份筛选附件功能这里。今天就跟大家分享下如何使用 Memcached 内存缓存优化 WordPress 后台媒体库加载。
WordPress 是直接通过查询数据库来获取博客的附件的月份,这样每次打开媒体库,或者添加媒体,打开「添加媒体」弹窗时候,都会到数据库去查询。用起来会有那么点卡顿,当然了,某些人连内存缓存都没开的,估计也不在乎这些卡顿。
虽然不会造成很大的问题,但是附件如果不新增删除,这个月份的数据基本不会变化,站长是用 WPJAM 插件配合 Memcached 将其缓存起来。不说有什么特殊效果,至少自己添加起媒体文件总舒服很多吧!
将下面的代码复制到当前主题的 functions.php
文件中,就可以使用内存来缓存媒体库的月份了:
// 使用 Memcached 内存缓存优化 WordPress 后台媒体库月份获取加载 - https://www.31idc.com add_filter('media_library_months_with_files', function($months){ $months = get_transient('wpjam_media_library_months'); if($months === false) { global $wpdb; $months = $wpdb->get_results("SELECT DISTINCT YEAR( post_date ) AS year, MONTH( post_date ) AS month FROM $wpdb->posts WHERE post_type = 'attachment' ORDER BY post_date DESC"); set_transient('wpjam_media_library_months', $months, WEEK_IN_SECONDS); } return $months; });
当然,你要是觉得不想要了,也可以删除后台媒体库附件月份的缓存。
// 删除后台媒体库附件月份的缓存 - https://www.31idc.com function wpjam_delete_media_library_months_cache(){ delete_transient('wpjam_media_library_months'); } add_action('edit_attachment', 'wpjam_delete_media_library_months_cache'); add_action('add_attachment', 'wpjam_delete_media_library_months_cache'); add_action('delete_attachment', 'wpjam_delete_media_library_months_cache');