Forums / Developer / *.ini files efficiency, good practices

*.ini files efficiency, good practices

Author Message

Piotrek Karaś

Thursday 15 May 2008 4:08:17 am

Few questions about technical details and good practices regarding use of *.ini configuration files.

1) When *.ini files are called for using ezini() operator in the templates, where do they reach? Directly to the filesystem locations, to cache files, or maybe to some memory resources?

2) Why isn't there ezini_group() operator (following what's available from eZ API methods)?

3) Should calling ezini() operator 10 times in a row be considered expensive? Or is that just getting prefetched resources?

4) If *.ini settings grabbed with ezini() operator are expensive, should it be avoided to use those in uncached parts of templates, the pagelayout for example?

Thanks,
Piotrek

--
Company: mediaSELF Sp. z o.o., http://www.mediaself.pl
eZ references: http://ez.no/partners/worldwide_partners/mediaself
eZ certified developer: http://ez.no/certification/verify/272585
eZ blog: http://ez.ryba.eu

André R.

Thursday 15 May 2008 5:27:04 am

1) Currently: first time you call ezini for a specific ini file, it will check for the existence of this file with all four variants (ini, ini.php, ini.append and ini.append.php ) in all possible locations in all activated extensions, when it is done it will create cache file name based on this array of file paths and then compare last modifed time on all those files compares to the cache file.
Cache is read or generated and put into ini instance's local variable cache.
The next time the file is requested (during the same page request) it is read from local variable cache.

For a somewhat more performance related approach ('ezini_performance_full_pluss_devmode.diff'):
http://issues.ez.no/IssueView.php?Id=12137&activeItem=24

2) good question, just added it as operator in OE my self ('ezoe_ini_section')

3) see 1)

4) Depends, earlier ini settings where compiled into the template when the template where compiled (unless you specified the dynamic flag), but I'm not sure it does that in trunk right now.

eZ Online Editor 5: http://projects.ez.no/ezoe || eZJSCore (Ajax): http://projects.ez.no/ezjscore || eZ Publish EE http://ez.no/eZPublish/eZ-Publish-Enterprise-Subscription
@: http://twitter.com/andrerom

Piotrek Karaś

Thursday 15 May 2008 6:37:48 pm

Thanks!

--
Company: mediaSELF Sp. z o.o., http://www.mediaself.pl
eZ references: http://ez.no/partners/worldwide_partners/mediaself
eZ certified developer: http://ez.no/certification/verify/272585
eZ blog: http://ez.ryba.eu

Maxime Thomas

Sunday 18 May 2008 10:43:58 pm

I've got another question concerning ini files :
Why eZSystems choose to put some reference data such as location data in an ini file rather than in a table ?

Maxime Thomas
maxime.thomas@wascou.org | www.wascou.org | http://twitter.com/wascou

Company Blog : http://www.wascou.org/eng/Company/Blog
Technical Blog : http://share.ez.no/blogs/maxime-thomas

eZ debug

Timing: Jan 20 2025 14:32:57
Script start
Timing: Jan 20 2025 14:32:57
Module start 'content'
Timing: Jan 20 2025 14:32:57
Module end 'content'
Timing: Jan 20 2025 14:32:57
Script end

Main resources:

Total runtime0.1525 sec
Peak memory usage2,048.0000 KB
Database Queries141

Timing points:

CheckpointStart (sec)Duration (sec)Memory at start (KB)Memory used (KB)
Script start 0.00000.0097 588.9766180.8281
Module start 'content' 0.00970.0068 769.804797.8828
Module end 'content' 0.01640.1360 867.6875526.5781
Script end 0.1524  1,394.2656 

Time accumulators:

 Accumulator Duration (sec) Duration (%) Count Average (sec)
Ini load
Load cache0.00382.4752200.0002
Check MTime0.00140.9117200.0001
Mysql Total
Database connection0.00090.558310.0009
Mysqli_queries0.106770.01271410.0008
Looping result0.00120.77421390.0000
Template Total0.135688.910.1356
Template load0.00090.592210.0009
Template processing0.134788.321510.1347
Override
Cache load0.00060.400810.0006
Sytem overhead
Fetch class attribute can translate value0.00060.410010.0006
XML
Image XML parsing0.00020.137810.0002
General
dbfile0.00362.3879200.0002
String conversion0.00000.005930.0000
Note: percentages do not add up to 100% because some accumulators overlap

CSS/JS files loaded with "ezjscPacker" during request:

CacheTypePacklevelSourceFiles
CSS0extension/community/design/community/stylesheets/ext/jquery.autocomplete.css
extension/community_design/design/suncana/stylesheets/scrollbars.css
extension/community_design/design/suncana/stylesheets/tabs.css
extension/community_design/design/suncana/stylesheets/roadmap.css
extension/community_design/design/suncana/stylesheets/content.css
extension/community_design/design/suncana/stylesheets/star-rating.css
extension/community_design/design/suncana/stylesheets/syntax_and_custom_tags.css
extension/community_design/design/suncana/stylesheets/buttons.css
extension/community_design/design/suncana/stylesheets/tweetbox.css
extension/community_design/design/suncana/stylesheets/jquery.fancybox-1.3.4.css
extension/bcsmoothgallery/design/standard/stylesheets/magnific-popup.css
extension/sevenx/design/simple/stylesheets/star_rating.css
extension/sevenx/design/simple/stylesheets/libs/fontawesome/css/all.min.css
extension/sevenx/design/simple/stylesheets/main.v02.css
extension/sevenx/design/simple/stylesheets/main.v02.res.css
JS0extension/ezjscore/design/standard/lib/yui/3.17.2/build/yui/yui-min.js
extension/ezjscore/design/standard/javascript/jquery-3.7.0.min.js
extension/community_design/design/suncana/javascript/jquery.ui.core.min.js
extension/community_design/design/suncana/javascript/jquery.ui.widget.min.js
extension/community_design/design/suncana/javascript/jquery.easing.1.3.js
extension/community_design/design/suncana/javascript/jquery.ui.tabs.js
extension/community_design/design/suncana/javascript/jquery.hoverIntent.min.js
extension/community_design/design/suncana/javascript/jquery.popmenu.js
extension/community_design/design/suncana/javascript/jScrollPane.js
extension/community_design/design/suncana/javascript/jquery.mousewheel.js
extension/community_design/design/suncana/javascript/jquery.cycle.all.js
extension/sevenx/design/simple/javascript/jquery.scrollTo.js
extension/community_design/design/suncana/javascript/jquery.cookie.js
extension/community_design/design/suncana/javascript/ezstarrating_jquery.js
extension/community_design/design/suncana/javascript/jquery.initboxes.js
extension/community_design/design/suncana/javascript/app.js
extension/community_design/design/suncana/javascript/twitterwidget.js
extension/community_design/design/suncana/javascript/community.js
extension/community_design/design/suncana/javascript/roadmap.js
extension/community_design/design/suncana/javascript/ez.js
extension/community_design/design/suncana/javascript/ezshareevents.js
extension/sevenx/design/simple/javascript/main.js

Templates used to render the page:

UsageRequested templateTemplateTemplate loadedEditOverride
1pagelayout.tpl<No override>extension/sevenx/design/simple/templates/pagelayout.tplEdit templateOverride template
 Number of times templates used: 1
 Number of unique templates used: 1

Time used to render debug report: 0.0001 secs