This shows you the differences between two versions of the page.
| performance [2010/06/13 17:04] 81.187.95.96 | performance [2024/05/31 06:48] (current) 104.194.134.81 1 | ||
|---|---|---|---|
| Line 1: | Line 1: | ||
| ====== Performance ====== | ====== Performance ====== | ||
| + | |||
| + | **Note:** template generation is usually a small fraction of application's runtime. Before worrying about template performance, use profiler (e.g. [[http://xdebug.org/|XDebug]] + [[http://kcachegrind.sourceforge.net/html/Home.html|KCacheGrind]]) to verify that you're not barking up the wrong tree. | ||
| + | |||
| ===== Opcode accelerator ===== | ===== Opcode accelerator ===== | ||
| Line 12: | Line 15: | ||
| ===== Avoiding stat() ===== | ===== Avoiding stat() ===== | ||
| - | On every request PHPTAL also checks if source template has changed. You can implement your own SourceResolver and Source classes to avoid file timestamp checks or to load TAL template sources in a different way. | + | On every request PHPTAL also checks if source template has changed. You can [[SourceResolver|implement]] your own ''SourceResolver'' and ''Source'' classes to avoid file timestamp checks or to load TAL template sources in a different way. | 
| - | If you want PHP not to touch disk at all, disable ''apc.stat'' in ''php.ini''. | + | If you want PHP not to touch disk at all, also disable ''apc.stat'' in ''php.ini''. | 
| **Note:** don't do this unless you absolutely need to. Disabling stat gives only tiny performance improvements, but without it PHP and PHPTAL won't notice when files are updated. | **Note:** don't do this unless you absolutely need to. Disabling stat gives only tiny performance improvements, but without it PHP and PHPTAL won't notice when files are updated. | ||
| + | |||
| + | ===== Faster TAL ===== | ||
| + | |||
| + | In templates expressions that have multiple path components (''foo/bar/baz'') require some extra run-time checks. You can change those expressions to use ''php:'' modifier (e.g. ''php:foo.bar['baz']''), which is a little bit faster. | ||
| + | |||
| + | Instead of using same complex expression multiple times, use ''tal:define'' to "cache" its value. Access to ''tal:define''d variables is quick. | ||
| + | |||
| + | Use ''phptal:cache'' to cache parts of templates that are very costly to generate. Currently there's no support for integration of ''phptal:cache'' with ''memcached'', but [[cache|it's planned]]. | ||
| + | |||
| + | 1 | ||