`
wodamazi
  • 浏览: 1420468 次
文章分类
社区版块
存档分类
最新评论

浅析magento执行sql文件夹下install-version.php下过程

 
阅读更多

在安装或升级magento模块时,不需要手动往mysql中导入需要的table,因为magento能够自己进行版本比较,决定是install还是upgrade。

下面就简单分析一下magento的执行过程。
执行任意url,进入index.php文件,执行run函数;
Mage.php中, 看run函数self::$_app = new Mage_Core_Model_App();
self::$_app->run(array(
‘scope_code’ => $code,
‘scope_type’ => $type,
‘options’ => $options,
));

进入Mage_Core_Model_App::run函数;

App.php中,看run函数中有_initModules方法

_initModules方法调用Mage_Core_Model_Resource_Setup::applyAllUpdates();
Setup.php中,所有的版本比较,和对table core_resource的操作,都在这里完成的。
看applyAllUpdates函数,$resources = Mage::getConfig()->getNode(‘global/resources’)->children();
得到所有的安装模块,进入applyUpdates函数
看applyUpdates函数,$dataVer是已安装的版本,就是从core_resource里取出的版本,为空的话就是未安装的模块,
$configVer是config.xml里的版本,这里决定了是install还是upgrade,或者是什么都不做。

相信到这里,你已经大概知道他的流程了。
有一点别忘记了,安装新的模块时,要先在后台system->cache management 先disable掉所有缓存,执行完任一url之后,再enable即可,否则模块可能会安装失败!


转载请注明出处!
分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics