由于本人博客空间8月份已到期,便新购一个虚拟主机想进行WordPress搬家,于是特意在网上查了些WordPress搬家教程,进行了综合总结,并结合这次实操经验,制作了这个算是比较全面完整的搬家教程。大体上来说搬家分为三步:
一、备份博客网站文件和数据库;
二、把网站文件传到新空间,在新空间导入数据库;
三、修改网站配置和数据库;
四、检查转移结果。
WordPress博客搬家的几种情况:
1. 换主机不换域名
2. 换域名不换主机
3. 换域名也换主机
第一步:1,wordpress插件关闭,网站程序打包下载并备份数据库
1.在原来的空间中把博客所有文件下载备份。要是原来空间支持在线解压缩,建议打包下载,这样下载大小变小了,时间也会节省很多。(本人基本时有什么文章更新,就用FTP同步备份到本地的,大家最好也有这个习惯,不然突然而来的事故会让追悔莫及!)
2.备份数据库。可以通过phpadmin,帝国备份王,或者WP-DBManager这样的数据库备份插件,您可以选择您会的,熟悉的一种方式来做。(建议对于sql,gz,zip多种格式尽量都备份一下,你不知道下一个主机会支持哪种)
第二步:上传博客文件,导入数据库
1.把博客文件用FTP传到新空间,和下载一样,要是新空间支持在线解压缩,建议打包上传,这样时间节省了很多,流量也能节省一部分。(WordPress目录是public_html/下,所以只要把之前在public_html/目录下的文件,上传到新主机的public_html/下即可。)
2.导入数据库.PHPMyAdmin,帝国备份王都可以做到。(你需要在新主机内创建一个数据库,然后将你之前导出的数据库,导入即可)
如图:
第三步:修改网站配置和数据库(关键)
1.修改wp-config文件,最好不要用记事本来修改,用notepad++或者UltraEdit等编辑器,把里面的数据库信息改为您新空间的数据库信息,如下:
/** WordPress 数据库的名称 */
define('DB_NAME', '你的新空间数据库名称');
/** MySQL 数据库用户名 */
define('DB_USER', '你的数据库用户名');
/** MySQL 数据库密码 */
define('DB_PASSWORD', '你的数据库登录密码');
/** MySQL 主机 */
define('DB_HOST', '你的数据库地址');
将你新的主机空间的数据库名称,数据库用户名和密码填进去即可。注意一下,MySQL主机这一项默认是’localhost’,如果你的是Windows主机,不用修改,如果是Linux主机,可能需要填上数据库的地址。
2. 进入新空间的phpadmin修改数据库:修改数据库表wp_options里的“siteurl”和“home”字段的值,改为你的新域名;
3.把用的域名解析到空间后,登录你wp后台,修改你blog的地址为你新的域名。
4.原来的文章里有链接或者图片是用以前域名的地址,所以还要修改那些地址。可以在phpadmin直接修改数据库或者velvet-blues-update-urls这个插件(推荐)。比如在phpadmin里,执行执行以下语句:
UPDATE wp_options SET option_value = REPLACE(option_value,'旧地址','新地址');
UPDATE wp_posts SET post_content = replace(post_content,'旧地址','新地址');
UPDATE wp_posts SET post_excerpt= replace(post_excerpt,'旧地址','新地址');
UPDATE wp_posts SET guid= replace(guid, '旧地址','新地址');
另外要注意,很多人都忽略的第四句语句。还有如果当初你的数据库表头不是默认的wp开头,你要修改成你自己数据库的表头,很多人都忘记了这点。不止是这四句,由于各个主题不同,也许你还要修改其他的表中信息,你最好逐一查看下。
第四步:检查转移结果,重新开启插件,经过上面的三步后,你已经可以用新网址浏览网站了,网站程序已经与数据库连接顺利,接着你要到wordpress后台修改默认的网站网址,登陆到其WordPress控制台,找到“设置”->“常规”,然后WordPress地址和博客地址中的旧域名,用新的域名进行替换。按照以上做了一般就完好的搬家成功了。
看看你的Blog,恭喜您成功搬家!
备注说明:
笔者在换空间换域名过程中,由于是在本地测试,还遇到了以下问题,顺便给出解决办法:
1,PhpMyAdmin导入数据库文件最大限制2048KB的修改:
解决办法:打开php.ini,找到 upload_max_filesize ,将值修改成更大。
2,本地测试时,通过localhost访问网站产生Internal Server Error提示:
解决办法:产生这个错误的信息的罪魁祸首就是静态化文件.htaccess,解决办法就是把这个静态化文件干掉,比如命名为1.htaccess,或者移到其他文件夹,甚至删掉,以后要用的时候再搬出来。
3,博客主题出错,显示“Parse error: syntax error, unexpected T_ENDIF in E:\aa\wamp\www\wordpress\wp-content\themes\xiaohan\sidebar.php on line 104”类似提示。
解决办法:你看下siderbar.php的第89行 < ? }?> 把< ? }?> 改成 < ?php }? > 。