[ 
https://issues.apache.org/jira/browse/SLING-12988?page=com.atlassian.jira.plugin.system.issuetabpanels:all-tabpanel
 ]

Joerg Hoh reassigned SLING-12988:
---------------------------------

    Assignee: Joerg Hoh

> Concurrent checks for a runmode can block under concurrency
> -----------------------------------------------------------
>
>                 Key: SLING-12988
>                 URL: https://issues.apache.org/jira/browse/SLING-12988
>             Project: Sling
>          Issue Type: Task
>    Affects Versions: Settings 1.4.0
>            Reporter: Joerg Hoh
>            Assignee: Joerg Hoh
>            Priority: Trivial
>
> We have a sling model like this:
> {noformat}
>     @PostConstruct
>     protected void init() {
>         Set<String> runmodes = slingSettingsService.getRunModes();
>         if (runmodes.contains(GlobalConstants.RUNMODE_PROD)) {
>             isProd = true;
>         }
>         if (runmodes.contains(GlobalConstants.RUNMODE_PUBLISH)) {
>             isPublish = true;
>         }
>         [checks for more runmodes]
> {noformat}
> if invoked under high concurrency, this can block on the .contains check, 
> because the Set returned by {{SlingSettingsServiceImpl.getRunModes}} is a 
> SynchronizedCollection.
> This is a rare condition (plus we also want to change the code to reduce the 
> number of such checks), but we should definitely just return a 
> UnmodifiabeCollection, it does not need to be a SynchronizedCollection (see 
> the comment at 
> https://github.com/apache/sling-org-apache-sling-settings/blob/e89534fcc34cae76fe97725567e5b03fbfc3800e/src/main/java/org/apache/sling/settings/impl/SlingSettingsServiceImpl.java#L229-L230)



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

Reply via email to