2010-11-01 22:03:50 +01:00
|
|
|
Improving Performance
|
|
|
|
=====================
|
|
|
|
|
2010-11-01 21:16:12 +01:00
|
|
|
Bytecode Cache
|
|
|
|
--------------
|
|
|
|
|
|
|
|
It is highly recommended to make use of a bytecode cache like APC.
|
|
|
|
A bytecode cache removes the need for parsing PHP code on every
|
|
|
|
request and can greatly improve performance.
|
|
|
|
|
2010-11-01 22:03:50 +01:00
|
|
|
"If you care about performance and don't use a bytecode
|
2010-11-01 21:16:12 +01:00
|
|
|
cache then you don't really care about performance. Please get one
|
2010-12-03 20:13:10 +01:00
|
|
|
and start using it."
|
|
|
|
|
|
|
|
*Stas Malyshev, Core Contributor to PHP and Zend Employee*
|
2010-11-01 21:16:12 +01:00
|
|
|
|
|
|
|
|
|
|
|
Metadata and Query caches
|
|
|
|
-------------------------
|
|
|
|
|
|
|
|
As already mentioned earlier in the chapter about configuring
|
|
|
|
Doctrine, it is strongly discouraged to use Doctrine without a
|
|
|
|
Metadata and Query cache (preferably with APC or Memcache as the
|
|
|
|
cache driver). Operating Doctrine without these caches means
|
|
|
|
Doctrine will need to load your mapping information on every single
|
|
|
|
request and has to parse each DQL query on every single request.
|
|
|
|
This is a waste of resources.
|
|
|
|
|
|
|
|
Alternative Query Result Formats
|
|
|
|
--------------------------------
|
|
|
|
|
|
|
|
Make effective use of the available alternative query result
|
|
|
|
formats like nested array graphs or pure scalar results, especially
|
|
|
|
in scenarios where data is loaded for read-only purposes.
|
|
|
|
|
|
|
|
Apply Best Practices
|
|
|
|
--------------------
|
|
|
|
|
|
|
|
A lot of the points mentioned in the Best Practices chapter will
|
|
|
|
also positively affect the performance of Doctrine.
|
|
|
|
|
|
|
|
|