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

Madhan Neethiraj updated RANGER-663:
------------------------------------
    Description: 
If two threads try to update one policy simultaneously then it can cause 
{{x_policy_resource}} table to have multiple values for a given {{policy_id, 
res_def_id}} combination.  When database gets in this state then that policy 
can't be read until the {{x_policy_resource_map}} and {{x_policy_resource}} 
tables are manually cleared up.

To reproduce the problem: from two separate shells, update the same policy 
using REST call in a tight loop. Soon the update calls will return failure with 
status code 400. At this point the policy is in a bad state in the database. 
After this point any attempt to update or read the policy will result in 
failure.

Expectation is that in case of simultaneous update only one update should 
succeed other should fail.

  was:
If two threads try to update one policy simultaneously then it can cause 
{{x_policy_resource}} table to have multiple values for a given {{policy_id, 
res_def_id}} combination.  When database gets in this state then tat policy can 
be read until the {{x_policy_resource_map}} and {{x_policy_resource}} tables 
are manually cleared up.

To reproduce the problem, from two separate shells, update the same policy 
using REST call in a tight loop. Soon updates will return failure with status 
code 400. At this point the policy is in a bad state in the database. After 
this point any attempt to update or read the policy will result in failure.

Expectation is that in case of simultaneous update only one update should 
succeed other should fail.


> Race condition during policy update causes policy to get in an bad state
> ------------------------------------------------------------------------
>
>                 Key: RANGER-663
>                 URL: https://issues.apache.org/jira/browse/RANGER-663
>             Project: Ranger
>          Issue Type: Bug
>          Components: admin
>    Affects Versions: 0.5.0
>            Reporter: Alok Lal
>            Priority: Critical
>             Fix For: 0.5.1, 0.6.0
>
>
> If two threads try to update one policy simultaneously then it can cause 
> {{x_policy_resource}} table to have multiple values for a given {{policy_id, 
> res_def_id}} combination.  When database gets in this state then that policy 
> can't be read until the {{x_policy_resource_map}} and {{x_policy_resource}} 
> tables are manually cleared up.
> To reproduce the problem: from two separate shells, update the same policy 
> using REST call in a tight loop. Soon the update calls will return failure 
> with status code 400. At this point the policy is in a bad state in the 
> database. After this point any attempt to update or read the policy will 
> result in failure.
> Expectation is that in case of simultaneous update only one update should 
> succeed other should fail.



--
This message was sent by Atlassian JIRA
(v6.3.4#6332)

Reply via email to