Zend Framework项目不使用Zend_Application

时间:2012-05-28 23:45:06

标签: php performance model-view-controller zend-framework

我一直在阅读许多sites甚至here,为了提高Zend Framework应用程序的性能,不是在引导程序中使用Zend_Application,而是找不到站点这证明了这一点。

你们知道有一个地方有这个方法描述并可能会提供一些代码样本吗?

由于

2 个答案:

答案 0 :(得分:6)

我只是把它扔在一起:

https://gist.github.com/2822456

转载以下完成。没有经过测试,只是我认为它(!)的一些想法可能会起作用。现在我已经了解了一下,我对Zend_Application,它的引导类以及可配置/可重用的应用程序资源有了更多的了解。 ; - )

// Do your PHP settings like timezone, error reporting
// ..

// Define path to application directory
defined('APPLICATION_PATH')
    || define('APPLICATION_PATH', realpath(dirname(__FILE__) . '/_zf/application'));

// Define application environment
defined('APPLICATION_ENV')
    || define('APPLICATION_ENV', (getenv('APPLICATION_ENV') ? getenv('APPLICATION_ENV') : 'production'));

// Ensure library/ is on include_path
set_include_path(implode(PATH_SEPARATOR, array(
    realpath(APPLICATION_PATH . '/../library'),
    get_include_path(),
)));

// Get autoloading in place
require_once 'Zend/Loader/Autoloader.php';
$autoloader = Zend_Loader_Autoloader::getInstance();
// Any additional configs to autoloader, like custom autoloaders

// Read config
$config = new Zend_Config_Ini(APPLICATION_PATH . '/configs/application.ini', APPLICATION_ENV);

// bootstrap resources manually:
// * create db adapter
// * create resource autoloaders with the mappings you need
// * etc

// Get the singleton front controller
$front = Zend_Controller_Front::getInstance();

// Set controller directory
$front->setControllerDirectory(APPLICATION_PATH . '/controllers');

// Or set module directory
$front->setModuleDirectory(APPLICATION_PATH . '/modules');

// Other front config, like throw exceptions, etc.
// ...
// 
// Create a router
$router = new Zend_Controller_Router_Rewrite();

// Add routes to the router
$router->addRoute('myRoute', new Zend_Controller_Router_Route(array(
    // your routing params
)));
// More routes...
// Alternatively, the routes can all be in an xml or ini file and you can add 
// them all at once.

// Tell front to use our configured router
$front->setRouter($router);

// Add an plugins to your $front
$front->registerPlugin(new My_Plugin());
// other plugins...

// Dispatch the request
$front->dispatch();

也可能有一些View / ViewRenderer要做的事情。但正如其他地方所指出的那样,ViewRenderer会带来非常重要的性能影响。如果性能问题,那么您将需要禁用ViewRenderer并使您的操作控制器使用$this->view->render('my/view-script.phtml')

调用自己的渲染

当您致电$front->dispatch()时,系统会自动创建$request$response个对象。如果你想在bootstrap上做一些特定的事情 - 比如在响应的Content-Type标题中设置charset - 那么你可以自己创建你的请求/响应对象,做你想做的事,然后将它附加到前面$front->setResponse($response);与请求对象相同。

虽然我看到我的示例使用了Zend_Loader_AutoloaderZend_config_Ini,而Padraic指出这会导致性能下降。下一步是通过使用数组进行配置,从框架中剥离require_once调用,注册不同的自动加载器等来解决这些问题,为读者留下一个练习......; - )

答案 1 :(得分:2)

嗨我不同意在bootstrap中没有使用Zend_Application,我还没有看到这个技术的具体例子。

我个人认为没有使用Zend_app引导您的应用程序的好处,假设a)您的行为是“Zend方式”和b)您的项目要么足够大,要么只是保证使用Zend框架(或任何事情)。

  

虽然Zend_App非常适合创建一致的复杂bootstraps   在标准化的结构中,它并非没有重要意义   性能达到基准性能。更直接的引导程序   (直到Zend_App到达时ZF的典型特征)要快得多,也可以   完成没有配置文件。

取自PádraicBrady链接。

对我来说上面的内容没有意义,他基本上只是说Zend_App非常适合复杂的bootstraps,但却增加了性能。但这不是任何框架/框架组件的前提吗?我知道Padraic是一个非常聪明的人,我确信他有自己的推理,但我也很乐意看到这个建议的例子/证据。

也许在回答您的问题时,您可以使用最新的Zend框架对基本应用程序进行基准测试,然后使用来自&lt; 1.10使用旧的非Zend_App方式,但我想说虽然显然不完美Zend_App显然更快地启动和运行大多数应用程序,所以这是否值得'性能打击'我想是开发人员。< / p>

这是一个链接,它有点涉及到你可能会追求但是参考模块化方法(仍然有趣,但同时):

http://www.osebboy.com/blog/zend-framework-modules/