[hibernate-issues] [Hibernate-JIRA] Issue Comment Edited: (HHH-6689) DefaultMergeEventListener changes CheckNullability flag - not thread save
Piotr Findeisen (JIRA)
noreply at atlassian.com
Fri Oct 28 05:07:20 EDT 2011
[ http://opensource.atlassian.com/projects/hibernate/browse/HHH-6689?page=com.atlassian.jira.plugin.system.issuetabpanels:comment-tabpanel&focusedCommentId=44192#comment-44192 ]
Piotr Findeisen edited comment on HHH-6689 at 10/28/11 4:06 AM:
----------------------------------------------------------------
Btw. it seems very probable that the sequence the following operations done in {{saveTransientEntity}} ([see source on github|https://github.com/hibernate/hibernate-core/blob/3.6/hibernate-core/src/main/java/org/hibernate/event/def/DefaultMergeEventListener.java#L409])
* read global checkNullability flag
* change global checkNullability flag to true
* restore global checkNullability flag to read value
when executed by 2 threads at the same time can *change checkNullability flag to {{true}} for ever*. For this to happen it's enough that
* first thread reads the flag and sets it temporarily to {{true}}
* second thread reads {{true}} (the temporary value)
* first thread completes {{merge}} and restores flag to the original value
* second threads completes {{merge}} and restores flag to the temporary value of {{true}}
was (Author: piofinsy):
Btw. it seems very probable that the sequence the following operations done in {{saveTransientEntity}}
* read global checkNullability flag
* change global checkNullability flag to true
* restore global checkNullability flag to read value
when executed by 2 threads at the same time can *change checkNullability flag to {{true}} for ever*. For this to happen it's enough that
* first thread reads the flag and sets it temporarily to {{true}}
* second thread reads {{true}} (the temporary value)
* first thread completes {{merge}} and restores flag to the original value
* second threads completes {{merge}} and restores flag to the temporary value of {{true}}
> DefaultMergeEventListener changes CheckNullability flag - not thread save
> -------------------------------------------------------------------------
>
> Key: HHH-6689
> URL: http://opensource.atlassian.com/projects/hibernate/browse/HHH-6689
> Project: Hibernate Core
> Issue Type: Bug
> Components: core
> Affects Versions: 3.6.5
> Environment: Websphere Application Server 7.0, DB2, Windows Server, Hibernate 3.6.5
> Reporter: John SMith
> Labels: hibernate
>
> saveTransientEntity() method saves the CheckNullability setting, changes it using the getFactory().getSettings().setCheckNullability method, and does save processing. After save processing, the saved value is restored.
> During load testing, we have had situations where the CheckNullability becomes set to TRUE and causes failures because of null checks.
> It has been difficult to debug, but it appears that this is not thread safe - multiple threads accessing this method can change the value of this setting.
> It can also be that a database error can cause an exception that will cause the checkNullability flan not to be reset.
--
This message is automatically generated by JIRA.
For more information on JIRA, see: http://www.atlassian.com/software/jira
More information about the hibernate-issues
mailing list