如何迁移测试的MAGENTO到正式运行的MAGENTO

时间:2024-08-07 23:35:50

或者这个题目叫做如何改变MAGENTO的运行目录

第一,我们需要在PHPMYADMIN备份整个MAGENTO的数据。备份数据并且存为.SQL.

在这儿假设你的测试网站在http://dev.site.com,而你准备迁移的正式运行的路径是http://livesite.com.
第二步,你必须打开你的备份文件(.SQL),查找并且替换所有的 “dev.site.com” 到“livesite.com”. Magento将完整的URL存在数据库中。所以你的网站是运行在完全URL基础之上的。我备份文件中的URL大约17000左右,够巨大的。这一步是必须的,而且必须在导入数据之前完成,不然新的MAGENTO将会全部瘫痪。

现在请不要基于导入你的SQL文件,你还有一步必须做,就是必须强制关闭相关的“数据库关键字的关系”。

请将下面的代码放在你的SQL代码的顶部:
SET @OLD_CHARACTER_SET_CLIENT=@@CHARACTER_SET_CLIENT;
SET @OLD_CHARACTER_SET_RESULTS=@@CHARACTER_SET_RESULTS;
SET @OLD_COLLATION_CONNECTION=@@COLLATION_CONNECTION;
SET NAMES utf8;
SET @OLD_UNIQUE_CHECKS=@@UNIQUE_CHECKS, UNIQUE_CHECKS=0;
SET @OLD_FOREIGN_KEY_CHECKS=@@FOREIGN_KEY_CHECKS, FOREIGN_KEY_CHECKS=0;
SET @OLD_SQL_MODE=@@SQL_MODE, SQL_MODE='NO_AUTO_VALUE_ON_ZERO';
SET @OLD_SQL_NOTES=@@SQL_NOTES, SQL_NOTES=0;

请将下面的代码放在你的SQL代码的底部:
SET SQL_MODE=@OLD_SQL_MODE;
SET FOREIGN_KEY_CHECKS=@OLD_FOREIGN_KEY_CHECKS;
SET UNIQUE_CHECKS=@OLD_UNIQUE_CHECKS;
SET CHARACTER_SET_CLIENT=@OLD_CHARACTER_SET_CLIENT;
SET CHARACTER_SET_RESULTS=@OLD_CHARACTER_SET_RESULTS;
SET COLLATION_CONNECTION=@OLD_COLLATION_CONNECTION;
SET SQL_NOTES=@OLD_SQL_NOTES;

现在你都准备好了,接下来,请压缩你的SQL文件,结尾为ZIP格式。因为我的原SQL文件大约8MB,但是压缩之后只有500KB,这样可以大大加速上传的时间。记住,请用PHPMYADMIN上传。

好了,现在请拷贝所有的文件和文件夹,从测试路径到实际运行的路径。

你的MAGENTO根目录是http://livesite.com,现在你需要打开http://livesite.com/app/etc/local.xml并且修改其中的数据库连接到(对应livesite.com).保存你的修改。现在你的MAGENTO应该可以工作了。
这个教程应该可以解决在不同主机中的迁移文件。但是,在个别情况下,你需要重新设置文件夹的权限(CHMOD),例如 /app, /app/etc, /var, /var/log, /var/session 等(755, 775, 777).

而且这儿还有一样事情你需要做,那就是 .htaccess文件. 如果你迁移是从一个服务器到另外一个服务器,而且所有的绝对路径是相同的,你不需要做任何事情。

但是如果你是从子文件夹http://livesite.com/store/移动出来,你需要修改.htaccess 中 “RewriteBase /products/” 部分。并且搜索替换SQL中相关的部分,例如“http://dev.site.com”换成“http://livesite.com//products/” 。

希望这些能够帮助你。转载自 MAGENTO.CC。