今天分享一下Emlog网站优化,如何加快网站的缓存速度,加快文章发布速度的方法Emlog是基于PHP+MYSQL的运行环境,那么缓存来源于MYSQL数据库,加快缓存速度,就是要加快MYSQL的查询速度针对MYSQL的查询优化,有建索引等等,还有重要一点“SELECT * ”类似这样的SQL查询语句要少用当表内某字段存在“NULL”值时,查询就会很慢,当数据量大了之后会更慢!所以有两个优化方向,尽量减少数据库中的NULL值(空字符串)其二就是优化SQL查询语句,建立索引那么针对EMLOG缓存,我们就可以针对性优化本站的优化就需要在用户表数据这里处理,因为用户过多导致用户缓存数据特别慢。1、用户缓存修改方法:打开根目录下的“include\lib\cache.php”将用户数据缓存这里替换一下,代码如下:未修改前:/**
* 用户信息缓存
*/
private function mc_user() {
$user_cache = array();
$query = $this->db->query("SELECT * FROM " . DB_PREFIX . "user");
while ($row = $this->db->fetch_array($query)) {
$photo = array();
$avatar = '';
if(!empty($row['photo'])){
$photosrc = str_replace("../", '', $row['photo']);
$imgsize = chImageSize($row['photo'], Option::ICON_MAX_W, Option::ICON_MAX_H);
$photo['src'] = htmlspecialchars($photosrc);
$photo['width'] = $imgsize['w'];
$photo['height'] = $imgsize['h'];
$avatar = strstr($photosrc, 'thum') ? str_replace('thum', 'thum52', $photosrc) : preg_replace("/^(.*)\/(.*)$/", "\$1/thum52-\$2", $photosrc);
$avatar = file_exists('../' . $avatar) ? $avatar : $photosrc;
}
$row['nickname'] = empty($row['nickname']) ? $row['username'] : $row['nickname'];
$user_cache[$row['uid']] = array(
'photo' => $photo,
'avatar' => $avatar,
'name_orig' => $row['nickname'],
'name' => htmlspecialchars($row['nickname']),
'mail' => htmlspecialchars($row['email']),
'des' => htmlClean($row['description']),
'ischeck' => htmlspecialchars($row['ischeck']),
'role' => $row['role'],
);
}
$cacheData = serialize($user_cache);
$this->cacheWrite($cacheData, 'user');
}替换为下面代码:/**
* 用户信息缓存
*/
private function mc_user() {
$user_cache = array();
$query = $this->db->query("SELECT uid,username,nickname,role,ischeck,photo,email,description FROM " . DB_PREFIX . "user");
while ($row = $this->db->fetch_array($query)) {
// $photo = array();
/*
$avatar = '';
if(!empty($row['photo'])){
$photosrc = str_replace("../", '', $row['photo']);
$imgsize = chImageSize($row['photo'], Option::ICON_MAX_W, Option::ICON_MAX_H);
$photo['src'] = htmlspecialchars($photosrc);
$photo['width'] = $imgsize['w'];
$photo['height'] = $imgsize['h'];
$avatar = strstr($photosrc, 'thum') ? str_replace('thum', 'thum52', $photosrc) : preg_replace("/^(.*)\/(.*)$/", "\$1/thum52-\$2", $photosrc);
$avatar = file_exists('../' . $avatar) ? $avatar : $photosrc;
}*/
$row['nickname'] = empty($row['nickname']) ? $row['username'] : $row['nickname'];
$user_cache[$row['uid']] = array(
'photo' => $row['photo'],
'avatar' => $row['photo'],
'name_orig' => $row['nickname'],
'name' => htmlspecialchars($row['nickname']),
'mail' => htmlspecialchars($row['email']),
'des' => htmlClean($row['description']),
'ischeck' => htmlspecialchars($row['ischeck']),
'role' => $row['role'],
);
}
$cacheData = serialize($user_cache);
$this->cacheWrite($cacheData, 'user');
}2、emlog核心优化方法:打开“admin\save_log.php”文件搜索:// 源代码
$CACHE->updateCache();
// 修改为:
$CACHE->updateCache(array('sta', 'tags', 'newlog', 'logsort', 'logtags'));
评论
172条评论锦.一诺 Lv.1
Android Webkit 4.0
Android 11 回复
666厉害
广东省中山市 电信
柒云吖 Lv.1
Chrome 109.0.0.0
Windows 回复
的撒大大
湖南省 电信
^kitten^2333 Lv.1
Android Webkit 4.0
Android 12 回复
哈哈哈
浙江省温州市 移动
a情玖 Lv.1
Chrome 109.0.0.0
Windows 回复
感谢楼主
,好人一生平安
广东省广州市 电信
五彩情人 Lv.1
Chrome 96.0.4664.104
Android 11 回复
你好
江苏省南京市 联通
546456 Lv.1
Chrome 86.0.4240.198
Windows 回复
不错
广东省广州市 电信
寒.2609493436 Lv.1
Chrome 97.0
Android 13 回复
额额
陕西省西安市 电信
. Lv.1
Chrome 86.0.4240.198
Windows 回复
江苏省南通市 南通供销学校
zhaohui Lv.1
Chrome 99.0.4844.88
Windows 回复
中国 移动
安妮理解 Lv.1
Chrome 99.0.4844.
Android 10 回复
我来了骨灰盒
陕西省宝鸡市 电信