wordpress数据库优化
‘壹’ 如何在WordPress后台直接优化Mysql数据库
为什么需要优化数据库
随着
MySQL
的使用,包括
BLOB
和
VARCHAR
字节的表将变得比较繁冗,因为这些字段长度不同,对记录进行插入、更新或删除时,会占有不同大小的空间,记录就会变成碎片,且留下空闲的空间。就像具有碎片的磁盘,会降低性能,需要整理,因此要优化。
如何优化
WordPress
数据库
而
WordPress
使用的数据库正是
MySQL,所以当你觉得
WordPress
速度比较慢的时候,对
MySQL
进行优化下,可以相当程度上提高
WordPress
的速度。我们可以通过
phpMyAdamin
对
MySQL
表进行优化:
在
PHPMyAdmin
优化
MySQL
表
使用
Optimize
DB
插件在WordPress
后台直接优化
MySQL
数据库
但是如果每次都要进入
PHPMyAdmin
优化
MySQL表,这样是非常麻烦的,今天推荐的插件:Optimize
DB
就能让你在
WordPress
后台直接优化
MySQL
数据表。
该插件安装非常简单,上传激活即可,激活之后,在
WordPress
后台
>工具(Tools)>
Optimize
DB
就能优化
MySQL
数据表了:
在
WordPress
后台优化
MySQL
表
上图中的
overhead
就是数据库冗余,点击
Optimize
Now,就可以优化。
文:我爱水煮鱼
‘贰’ WordPress 新的建网站速度太慢了,怎么办
第一、选择速度好的主机
一款优秀、稳定、速度快的虚拟主机、VPS是影响我们WORDPRESS网站打开速度的关键因素之一,不管我们是使用哪种CMS搭建网站,我们需要选择好主机。不同的商家、不同的数据中心,速度是不一样的。比如我们一般选择VPS搭建中文网站,选择较多的是日本、洛杉矶等物理距离离我们距离较近的海外商家机房。如果是英文网站,即便海外的差距比较小,但是还是要根据不同的用户群体选择机房,比如我们有针对欧洲用户的,那最好还是选择欧洲的机房产品。
即便我们在国内主机需要BEIAN,但是鉴于速度和稳定性、长久性考虑,如果我们是正规的,希望长期坚持的,老左还是建议选择国内的服务商。
第二、选择合适的主题
很多WordPress用户,尤其是刚刚接触网站的看到WP拥有无数个漂亮的主题都希望自己的博客/网站也装扮的很漂亮(每一个新站长都是这样的),然后就会选择各种复杂的,甚至是海外的商务主题。其实越是复杂的主题加载的图片、外部调用、JS等信息就多,势必会导致整个页面的加载速度。
所以,我们在选择主题的时候,就要考虑主题的加载速度,我们国内的网速与国外不好比,有些外部加载的资源需要本地化,以及图片的尺码大小需要考虑我们的带宽速度。不能为了好看导致用户访问还没打开,就给你的漂亮网站关闭。
第三、控制图片以及JS的使用
不论是在页面装饰的图片,还是我们文章中的图片,建议选择和使用合理的压缩尺码和大小,这样有利于加载图片。有必要的时候也需要用到图片缓冲lazyload.js插件(最好不用插件,直接代码化)。对于样式和JS的调用,目前比较流行的做法是CSS放到页面上部,JS放到页面底部,这样加载速度比较好。
第四、有必要使用CDN加速
老左个人不建议使用所谓的第三方CDN加速(分享5款国内免费CDN服务商及使用点评),即便在一定程度上起到加速功能,但是据说有些地区用了加速之后反而不如直接的打开快。但是,如果有存储资源的,比如图片或者文档资源类,可以单独使用加速服务,比如七牛等第三方CDN存储服务,把占用资源的信息用于第三方加速存储。
第五、解决Google 字体加载问题
不论是默认的WORDPRESS程序主题也好,还是下载的第三方主题中也包括GOOGLE 字体。我们需要安装Disable Google Fonts插件可以解决问题,如果主题中也有字体加载,我们还需要到对应的主题代码中把googleapis替换成useso就可以。当然,对应的其他外部资源调用的,也需要考虑本地化。
第六、定期整理数据库以及草稿版本
WORDPRESS默认的时候会自动生成一些版本信息,占用比较大的数据库缓存,我们可以使用WP Cleaner插件定期清理。同时,我们的MYSQL数据库也需要定期维护优化,一般一周维护一次足够。WP-Optimize数据库优化插件也是可以的。对于这些插件我们用的时候安装、启动就可以,不用的时候删除。
总之,我们如果希望Wordpress轻便,在主题的选择上要轻便,在内容上要尽量的少图片、小图片,最好使用第三方存储CDN加速资源,我们使用的主机/VPS速度也要好。每一个细节都完善一些,WORDPRESS还是一款不错的CMS选择。
‘叁’ wordpress 数据库多大时,访问速度变慢
第一、取消谷歌Open sans字体加载
如果我们使用的默认主题,可能前台也会有,如果我们使用的自己制作的或者第三方的主题,一般前台是没有的,只有我们在登陆账户后的前台和后台打开变慢,主要是不便于我们自己的访问和维护。我们可以通过在后台插件搜索"Disable Google Fonts",下载安装激活这个插件就可以解决这个问题。
第二、清除不必要的头部加载
看到这里的时候我们可以到自己的WP网站源代码看看,在头部位置是不是看到很多的JS和CSS加载项目,多达十几条,然后我们可以看看类似大前端这样的主题源代码,头部基本上没有多余的加载,所所以他们的这类主题加载速度和打开速度非常的快,所以我们有必要清除不必要的JS加载,在"WordPress提速优化篇:清理HEAD头部多余脚本"也有提到,但是研究的还不够细致,等下面有时间把大前端主题的屏蔽JS功能研究一下。
第三、删除不必要的插件
理论上,能不用插件不用插件,在上周老左在帮网友解决问题的时候,看到他的网站使用的是阿里云机房,照理说速度应该比较好,但是打开速度都不如美国东部机房速度,登陆其网站后台发现使用将近20多个插件,1G内存的VPS,内存已经占用70%,一个新建立的网站开始就有这样的负载,以后如果有流量后咋办?
第四、是否使用商业化主题
我个人在使用WORDPRESS的时候喜欢使用简单的主题,然后慢慢修改成自己喜欢的用户体验效果,不喜欢使用主题太复杂的,尤其是海外那些有特别复杂后台的主题,这样的主题一来不太安全,二来加载速度特别慢,毕竟要实现这样的绚丽效果需要用到很多JS和CSS,甚至还嵌入前端框架。我个人理解的是网站不需要太复杂和绚丽,简单轻便,主要在于内容够有内涵和吸引力。
第五、数据库缓存文件负担
在默认的时候,我们在后台写文章会时隔一段时间自动给我们保存成修订版本,这样的修订版本会自动保存到数据中心,即便我们在前台是看不到的,这样像老左博客更新一篇文章需要花费几十分钟甚至1-2个小时的时候修订版本会很多很多,这就是为什么很多人发现ID不连续的原因,这样在我们有1000篇文章时候可能会有3000个记录文章,甚至在长久的运营之后会产生几千上万的记录(这就是为什么很多人说开始速度还可以,以后速度越来越不好)。我们需要删除修订版本,不让修订版本添加到数据中心。
解决方法:在wp-config.php文件中添加"define('WP_POST_REVISIONS', false);"代码。
第六、检查是否有垃圾评论
这一点很重要,之前老左的一台LINODE VPS一直给我发报警邮件说机器CPU超标达到400%,而且在其上面的网站打开速度特别慢,我开始以为又被人攻击,然后通过日志和后台一看,每秒钟有几十个的评论在增加,即便评论内容不会显示在前台,但是会加载到数据库中,这样就增加了整个网站和机器的负载。我们需要用工具屏蔽、验证垃圾评论,尤其是软件群发的评论需要搞定他们。
比如我们需要激活Akismet以及使用类似需要验证码才可以评论的功能/插件,增加软件群发评论的难度。
第七、优化图片缓存
尤其是当下扁平化体验的需求,我们喜欢用较多的图片内容,比如老左博客教程中用到大量的图片,但加载图片是比较慢的,我们可以用到类似图片缓冲的插件或者JS效果,比如可以用到jQuery lazy load plugin插件解决图片缓冲,而且用户体验也比较好,图片是从上到下加载的,有一个渐变效果。
同时,我们也需要用到WP-Super-Cache插件,这样可以缓存内容,尤其是我们的WP是用伪静态的时候,数据越大,占用的CPU资源就比较大,甚至有很多虚拟主机商比较讨厌用户使用WP程序。(当然也比较讨厌DEDECMS,安全性差)
总之,wordpress既然能成为当下用户最大,最流行的CMS系统,肯定有他的优势之处,但我们也要学会如何从细节优化。
‘肆’ wordpress博客MySQL数据库容量用超,求解怎么给MySQL数据库瘦身
恶意加的广告是加在常用表里了吗?还是别的表?别的表还好说,常用表就麻烦了,用sql语句也要找到相应的正则吧。
DELETE FROM wp_comments WHERE 'wp_comments'.'comment_ID' > 10000;
是删除表单中文章ID编号10000以后的文章,文章ID是按照创建时间递增的,这命令应该可以实现你们要求。
‘伍’ Wordpress插件过多很臃肿,怎么优化
缓存就指很多方便了,比如CDN缓存、静态缓存、数据库缓存、浏览器缓存等等。
1、CDN缓存:CDN的话最好是备案了再起飞,因为大多数没备案的CDN都是给美国节点,而很多人是香港服务器,那岂不是绕着太平洋跑?另外,CDN需要正确的配置(写缓存规则)才能够达到最好的效果。
2、静态数据库缓存:这个呢就不做推荐了,各有各的优点,自己比较效果吧。
3、浏览器缓存:这里呢说一下,如果长期更新浏览器缓存不要搞太久,很多人在网络云加速设置个一年什么的。ServiceWorker的话可以试试,离线打开是不是很装逼呢
精简是重要的
很多优秀的主题包含了很多不必要的功能,这时候就需要适当的精简,毕竟只有骨骼轻才可以飞。
插件的话能用纯代码就用纯代码,插件什么的卡死了。
一些CSS/JS文件要适当的压缩合并,减少请求数,因为在HTTP/1.1中每个文件都要握手。
Gzip的话是有必要开的,大家也知道打包文件更小吧。
HTTP/2压缩了请求头,而且合并了请求,也就是说全站两个域名只需两次请求。
SPDY的话是谷歌的一个项目,本身是为了加快HTTP,不过现在的HTTP/2已经包含了其大部分功能,谷歌也要放弃该项目了
支持HTTP/2的CDN有CloudFlare、腾讯云、又拍云、上海云盾、360网站卫士、魔门云(非联盟已回源,备案无国内,只有一两个节点,巨坑!)等等。
定时清理WordPress的垃圾
压缩合并让请求更快
动静分离让静态资源国内加载
如果你是国外主机的话,这个方法十分管用,可以把图片、CSS、JS文件等托管到国内,不过如果有了HTTP/2的话建议不要搞,因为又要与一个域名握手了。
HTTP/2 SPDY大法好
InstantClick预加载
这个之前提到过,InstantClick当访客鼠标悬浮在a链接时,InstantClick会异步请求这个页面,当访客点击时,便瞬间切页,有木有飞起?不过这玩意会扯出一大堆Bug,像统计、高亮什么的都需要重载,萌新就别弄了,国内估计也就泽泽大佬的Yo模板自带了,至于WordPress还没见过,主题作者也不想撤扯出一大堆问题让用户天天问吧。
经常听一群人说清电脑辣鸡,windows有垃圾,WordPress当然也有,例如自动草稿这样的肯定是不要的东西,这里呢推荐WP Clean Up插件,国人写的。
希望可以帮助到你,望采纳!
‘陆’ 如何提高WordPress访问速度与性能的四大方法
一、插件加速WordPress
主要是通过控制插件数量,配合使用页面缓存插件,以及数据库优化插件等结合。具体使用教程这里不详细说明,大家可以搜索相关教程即可。
二、主题优化加速WordPress
1.主题代码加速:
代码决定了WordPress加载的速度,浏览你博客的速度在很大程度上是这个因素决定的(在同样的网络环境下),用户加载网页的时间有80%花在这上面。要想你的WordPress飞速跑起来,代码层次的优化是非常必要的。其实,压缩CSS和JS也是非常简单的事情,真的,不是你想象中的那么难。压缩CSS,推荐使用styleneat.com,操作方式非常简单,但是却能带来很大的速度提升。
推荐方法是:把CSS放在开头,把JS放在结尾 ;用Gzip压缩网页,WP CSS插件也可以实现这一功能;不要把CSS和js直接写入网页中,应加载外部;去除JS和CSS中的冗余,最好把JS文件放在主题的footer.php里,在CSS和JS的优化上,CSS要首先载入,JS要最后载入;外部调用调用Google Code里面的大型框架 – Ajax Libraries API。对这些框架的载入,让Google的服务去承担:) 常用的有:
jQuery
prototype
script.aculo.us
MooTools
dojo
调用方法就不必介绍了吧。
2.主题图片优化:
优化图片的好处是显而易见的,首先减少HTTP请求数,可以节省大量的带宽资源,这是代码优化中很基础也很重要的一个环节,其次,图片优化,可以大大提供博客整体的载入速度。而一个网页中的所使用到的图片(诸如小图标之类的)往往占有很大部分的HTTP请求,所以将这些图片合并成一张大的背景图时,不但可以减少图片整体的大小外,最重要的还是可以减少HTTP请求数。
相关方法就是利用CSS SCRIPT技术和一些图片压缩优化的方法来实现。
图片压缩建议使用,smush.it。
3.删除冗余的主题函数:
WordPress主题函数很多,每个函数也都有自己的作用,但是在一些时候,我们可以不使用函数,而直接使用具体的链接地址,这样就避免了函数对数据库的操作,从而提高了WordPress主题整体的载入速度。
三、数据库优化加速WordPress
优化和修复你的数据库
你应该定时(每周或每半个月)登录一下你的phpmyadmin,然后对你的各个WordPress表进行优化和修复,很简单,你只需要选中这些表,然后进行”Optimize table”和”Repair table”即可。(如果要慎重起见,你最好还是同时备份一下你的数据库。安全和性能同时抓,何乐而不为?)
或者使用插件优化数据库:目前公认最好的数据库优化插件是:Optimize DB
四、其他方法加速WordPress:
1.使用可靠的图片托管服务
尽可能将文章中的图片保存到其他地方,如Google Picasa、Flickr等。而不是上传到你的服务器上。这样做可以使Web服务器减少很多平均CPU负载/存储要求。
2.服务器层次加速WordPress
置换更好的主机,部分博友有自己的服务器或者VPS,可以针对VPS或者独立服务器的。使用轻量级、高性能的Nginx,PHP字节码缓存组件apc
3.为网页静态元素设置过期时间(以Nginx为例),以及增加Etags等。
4.关闭日志修订记录功能
禁用并删除 WordPress 文章修订记录,或者定期用Delete-Revision插件清理。
‘柒’ wordpress 源代码中内嵌了一些无法访问的url拖累访问速度
wordpress必装插件,wordpress网站装好了之后,为了更好的优化网站少不了安装插件优化。今天给大家推荐wordpress必装插件以及工具。只需输入域名选择wordpress主题或模板(内置90000套主题模板选择)。一个网站就这样搭建完成。软件上还覆盖各种主题功能以及全套SEO插件。等下会以图片的形式给大家展示。大家注意看图。一键建站+行业内容采集+伪原创+主动推送给搜索引擎收录。
网站地图,又称站点地图,它就是一个页面,上面放置了网站上需求搜索引擎抓取的一切页面的链接(注:不是一切页面)。大多数人在网站上找不到本人所需求的信息时,可能会将网站地图作为一种弥补措施。搜索引擎蜘蛛十分喜欢网站地图。
制作网站地图的工具十分多,如sitemapX,其他软件功用大同小异。网站地图放置在网站的根目录,有一份或者多份,只要一份的状况是页面比较少,网站地图文件较小,蜘蛛读取速度快,反之蜘蛛读取速度慢,所以分开多个文件放置,不由于读取问题影响权重。另外,robots协议文件控制搜索引擎抓取范围、时间频率等,所以应该把网站地图放在robots的最后面,先恪守robots抓取范围。
出现404错误是在网站页面被收录了之后,后面又被删除,在搜索引擎再次点击即出现404错误。这对用户体验来说是相当糟糕的,但404错误又是无法避免的,中小型网站页面数量不会很多,但是大型门户网站,论坛等,数量就多了。404在seo优化中,尤其是在跳出率和PV上,起到关键作用。
什么是404错误
先看看seo名词解释:HTTP 404或Not Found错误信息是HTTP的其中一种“标准回应信息”(HTTP状态码),此信息代表客户端在浏览网页时,服务器无法正常提供信息,或是服务器无法回应且不知原因。
出现404错误的影响
自定义404错误页面是增强用户体验的很好的做法,但在应用过程中往往并未注意到对搜索引擎的影响。 搜索引擎蜘蛛在请求某个URL时得到“404”状态回应时,即知道该URL已经失效,便不再索引该网页,并向数据中心反馈将该URL表示的网页从索引数据库中删除,删除过程有可能需要很长时间;
搜索引擎得到“200”状态码时,则会认为该url是有效的,便会去索引,并会将其收录到索引数据库,结果是这两个不同的url具有完全相同的内容,搜索赢球认为这是复制的网页。轻则被搜索引擎降权,重则会K掉网站。静态页面为路径的网站,在优化和删除某些后台编辑的文章时,一定要把网站的生成静态页面(完整路径的页面)删除,同时向网络进行死链提交。
这里要提到特殊的tag功能,dedecms能按照文章关键字自动生成tag标签。如果tag标签也被收录,而你删除了某些tag标签,都会弹出“dedecms提示:该标签已删除”的错误页面,会产生非常多重复且低质量的页面。由于不是返回404,无法通过提交404错误,删除这些快照。如果你有大量的tag标签页被收录,404页面的设置方法很多,以万网虚拟机为例,Apache下设置404错误页面。方法很简单,只需在.htaccess 文件中加入如下内容即可:ErrorDocument 404 /notfound.php。也可在万网空间设置里面设置404页面,只要选好404模板。
制作死链文件筛查网站内部存在的死链,并将这些死链页面设置成为404页面,即网络访问它们时返回404代码。将需提交的死链列表制作成一个死链文件,制作方法请参阅网络错误页面提交帮助文档(与sitemap格式及制作方法一致)
‘捌’ 怎么清理优化wordpress数据库
使用数据库优化清理插件
‘玖’ 如何清理WordPress残留垃圾数据
1、彻底清除残留WordPress主题垃圾数据
经常换WP主题删WP主题,装插件删插件很正常,但是简单的删除并不彻底,数据库会有残留,多余的数据保留在post_meta表格里,久而久之就成了一堆可观的垃圾。可使用下面的SQL语句来清除不需要的post meta值。有益于加快数据库运行速度,减小数据。
处理方法:清理wp_postmeta数据表,删除文章Meta标签,执行SQL语句,(建议先备份数据库,以上商法,后进者网络均已测试无误)
DELETE FROM wp_postmeta WHEREmeta_key = ‘_edit_lock’;
DELETE FROM wp_postmeta WHEREmeta_key = ‘_edit_last’;
2、彻底删除WP草稿修订版本残留数据
后台编辑文章时,系统会自动保存多个修订的副本。过多的修订记录会加重数据库负担造成资源浪费,数据库越来越庞大,增加了数据检索影响页面的加载时间。
处理方法:清理wp_posts数据表,删除草稿修订版本,执行SQL语句
DELETE a,b,c FROM wp_posts a
LEFT JOIN wp_term_relationships bON (a.ID = b.object_id)
LEFT JOIN wp_postmeta c ON (a.ID =c.post_id)
WHERE a.post_type = ‘revision’
注意: 此方法将删除所有的文章的所有修订版,包括相关的meta数据。
也可以使用插件WP-Cleane处理。
3、批量删除WordPress所有垃圾评论
遇到N多垃圾评论,一个一个删除的话会崩溃。可使用下面的SQL语句查询,批量删除WP垃圾评论也不是难事。
处理方法:执行SQL语句
DELETE FROM wp_comments WHEREcomment_approved = ‘spam’;
0 = Comment Awaiting Moderation
1 = Approved Comment
spam = Comment marked as Spam
先用上面方法删除之前的垃圾评论,以后推荐使用Akismet插件,Akismet拥有广泛的垃圾留言过滤系统,省下很多事。
4、删除WordPress未使用标签垃圾数据
WordPress数据库中,如果你使用一个查询语句手动来删除旧的文章,旧的标签却仍然会保留并在你的标签云/列表中出现。你可以使用下面的方法识别未使用的标签并将它删除。
处理方法:执行SQL语句
SELECT * FROM wp_terms wt
INNER JOIN wp_term_taxonomy wtt ONwt.term_id=wtt.term_id
INNER JOIN wp_term_relationshipswtr ON wtr.term_taxonomy_id=wtt.term_taxonomy_id
LEFT JOIN wp_posts wp ONwp.ID=wtr.object_id
WHERE taxonomy=’post_tag’
AND ID IS null
AND NOT EXISTS(SELECT * Fromwp_terms wt2
INNER JOIN wp_term_taxonomy wtt2 ONwt2.term_id=wtt2.term_id WHERE wtt2.parent=wt.term_id) ORDER BY name;
有的人也许会问,这么复杂的SQL语句,应该有WP插件开发者开发相应的数据库优化插件吧。没错还真有相关的优化WP数据库插件。
WordPress数据库优化插件 wp db manager :可以优化、修复、定期备份、执行mysql命令的插件。安装好这个插件之后,可以选择Optimize DB优化数据库。