[ 
https://issues.apache.org/jira/browse/GROOVY-11571?page=com.atlassian.jira.plugin.system.issuetabpanels:comment-tabpanel&focusedCommentId=17932120#comment-17932120
 ] 

Eric Milles commented on GROOVY-11571:
--------------------------------------

Sure. A separate issue for the other attributes would be fine. 

> Performance problem in Eclipse RCP/OSGi/Equinox environment
> -----------------------------------------------------------
>
>                 Key: GROOVY-11571
>                 URL: https://issues.apache.org/jira/browse/GROOVY-11571
>             Project: Groovy
>          Issue Type: Bug
>          Components: groovy-runtime
>    Affects Versions: 4.0.25
>         Environment: Eclipse RCP 4.25
>            Reporter: Torsten Witte
>            Assignee: Paul King
>            Priority: Major
>
> We have an Eclipse RCP application that includes Groovy (4.0.25) so that 
> users can customise it via Groovy scripts (groovy, groovy-datetime, 
> groovy-dateutil, groovy-json, groovy-templates, groovy-xml, groovy-yaml).
> Unfortunately, we have noticed that the compilation of each individual script 
> takes several seconds (e.g. 3 seconds and more for a tiny script).
> We have discovered that it will be faster if we remove some Groovy libs (e.g. 
> groovy-yaml), but that is not an option because we need the dependencies.
> Then we have noticed that the scripts compile in a few milliseconds if the 
> application has been started with the Eclipse "-clean" parameter 
> ("osgi.clean").
> The scripts can therefore be compiled much faster!
> However, the "-clean" parameter slows down the start of the application, as 
> the OSGi configuration has to be recreated each time, and that is also not an 
> option for us.
> It seems that Eclipse/OSGi/Equinox holds some wiring information in its 
> configuration folder which slow down the Groovy compile times (more precise: 
> the class loading).
> When drilling down into the problem, we got as far as buddy class loading, 
> where the time is lost.
> The reason is in the {{MANIFEST.MF}} of the {{groovy_<version>.jar}}:
> {noformat}
> Eclipse-BuddyPolicy: dependent
> {noformat}
> Setting the value to "global" fixes the problem and the scripts are always 
> compiled in a few milliseconds, whether starting the application with or 
> without the "-clean" parameter.
> {noformat}
> Eclipse-BuddyPolicy: global
> {noformat}
> The documentation of the [Buddy Class 
> Loading|https://wiki.eclipse.org/Context_Class_Loader_Enhancements#Buddy_Policy_2]
>  says:
> bq. dependent - Consults all bundles that directly or indirectly depend on 
> the bundle. An indirect dependency can be introduced by bundles that use 
> Require-Bundle with the visibility directive set to reexport. Note that this 
> casts a rather wide net and may introduce performance problems as the number 
> of bundles increase.
> We use Require-Bundle in our {{MANIFEST.MF}} but without visibility reexport:
> {noformat}
> Require-Bundle: [...],
>  groovy;bundle-version="4.0.25",
>  groovy-datetime;bundle-version="4.0.25",
>  groovy-dateutil;bundle-version="4.0.25",
>  groovy-json;bundle-version="4.0.25",
>  groovy-templates;bundle-version="4.0.25",
>  groovy-xml;bundle-version="4.0.25",
>  groovy-yaml;bundle-version="4.0.25",
>  [...]
> {noformat}
> Are there reasons why the entry "Eclipse-BuddyPolicy" in the {{MANIFEST.MF}} 
> of the {{groovy_<version>.jar}} is set to "dependent"?
> Is it possible to set the value to "global" in further releases?
> (Another problem with the Eclipse-BuddyPolicy is described in GROOVY-6491)



--
This message was sent by Atlassian Jira
(v8.20.10#820010)

Reply via email to