Uploaded image for project: 'MariaDB Server'
  1. MariaDB Server
  2. MDEV-4017

GET_LOCK() with negative timeouts has strange behavior

Details

    • Bug
    • Status: Closed (View Workflow)
    • Minor
    • Resolution: Fixed
    • 10.0.0, 5.5.28a, 5.3.11, 5.2.13, 5.1.66
    • 5.5.45, 10.0.21, 10.1.7
    • OTHER
    • 5.5

    Description

      I know that passing a negative timeout to GET_LOCK() makes no sense. But if you do it by mistake (perhaps with dynamic sql) there are 2 cases:

      • If the number is high, it is like passing 0:

        MariaDB [(none)]> SELECT GET_LOCK('x', -100);
        +---------------------+
        | GET_LOCK('x', -100) |
        +---------------------+
        |                   0 |
        +---------------------+
        1 row in set (0.01 sec)

      • if number is very low, it considers it as a positive number (you will need to kill the query):

        SELECT GET_LOCK('x', -1500000000);

        In both cases, I get no errors or warnings.

      Attachments

        Issue Links

          Activity

            f_razzoli Federico Razzoli created issue -

            Of course the first case is ok, but I think that the second case (very low negatives considered as positive) is a bug.

            f_razzoli Federico Razzoli added a comment - Of course the first case is ok, but I think that the second case (very low negatives considered as positive) is a bug.
            elenst Elena Stepanova made changes -
            Field Original Value New Value
            Assignee Elena Stepanova [ elenst ]

            It's an upstream issue, except that in MySQL up to and including 5.6 even GET_LOCK('x', -10) hangs seemingly forever (as well as in MariaDB 5.1/5.2).

            elenst Elena Stepanova added a comment - It's an upstream issue, except that in MySQL up to and including 5.6 even GET_LOCK('x', -10) hangs seemingly forever (as well as in MariaDB 5.1/5.2).
            elenst Elena Stepanova made changes -
            Fix Version/s 10.1.0 [ 12200 ]
            Affects Version/s 5.1.66 [ 10801 ]
            Affects Version/s 5.2.13 [ 10800 ]
            Affects Version/s 5.3.11 [ 11700 ]
            Affects Version/s 5.5.28a [ 11701 ]
            Affects Version/s 10.0.0 [ 10000 ]
            Assignee Elena Stepanova [ elenst ]
            Labels upstream
            serg Sergei Golubchik made changes -
            Description I know that passing a negative timeout to GET_LOCK() makes no sense. But if you do it by mistake (perhaps with dynamic sql) there are 2 cases:

            * If the number is high, it is like passing 0:

            MariaDB [(none)]> SELECT GET_LOCK('x', -100);
            +---------------------+
            | GET_LOCK('x', -100) |
            +---------------------+
            | 0 |
            +---------------------+
            1 row in set (0.01 sec)

            * if number is very low, it considers it as a positive number (you will need to kill the query):

            SELECT GET_LOCK('x', -1500000000);

            In both cases, I get no errors or warnings.
            I know that passing a negative timeout to GET_LOCK() makes no sense. But if you do it by mistake (perhaps with dynamic sql) there are 2 cases:

            * If the number is high, it is like passing 0:
            {noformat}
            MariaDB [(none)]> SELECT GET_LOCK('x', -100);
            +---------------------+
            | GET_LOCK('x', -100) |
            +---------------------+
            | 0 |
            +---------------------+
            1 row in set (0.01 sec)
            {noformat}
            * if number is very low, it considers it as a positive number (you will need to kill the query):
            {noformat}
            SELECT GET_LOCK('x', -1500000000);
            {noformat}
            In both cases, I get no errors or warnings.
            serg Sergei Golubchik made changes -
            Fix Version/s 5.5.38 [ 15400 ]
            Fix Version/s 10.1.0 [ 12200 ]
            serg Sergei Golubchik made changes -
            Fix Version/s 10.0.11 [ 15200 ]
            serg Sergei Golubchik made changes -
            Fix Version/s 10.0.12 [ 15201 ]
            Fix Version/s 10.0.11 [ 15200 ]
            serg Sergei Golubchik made changes -
            Fix Version/s 5.5.39 [ 15800 ]
            Fix Version/s 5.5.38 [ 15400 ]
            serg Sergei Golubchik made changes -
            Workflow defaullt [ 25793 ] MariaDB v2 [ 44275 ]
            serg Sergei Golubchik made changes -
            Fix Version/s 10.0.13 [ 16000 ]
            Fix Version/s 10.0.12 [ 15201 ]
            ratzpo Rasmus Johansson (Inactive) made changes -
            Workflow MariaDB v2 [ 44275 ] MariaDB v3 [ 63775 ]
            svoj Sergey Vojtovich made changes -
            Assignee Sergey Vojtovich [ svoj ]

            bar, please review fix for this bug.

            svoj Sergey Vojtovich added a comment - bar , please review fix for this bug.
            svoj Sergey Vojtovich made changes -
            Assignee Sergey Vojtovich [ svoj ] Alexander Barkov [ bar ]
            Status Open [ 1 ] In Review [ 10002 ]

            Okey to push, with a minor suggestion.

            bar Alexander Barkov added a comment - Okey to push, with a minor suggestion.
            bar Alexander Barkov made changes -
            Status In Review [ 10002 ] Stalled [ 10000 ]
            bar Alexander Barkov made changes -
            Assignee Alexander Barkov [ bar ] Sergey Vojtovich [ svoj ]
            svoj Sergey Vojtovich made changes -
            Component/s OTHER [ 10125 ]
            Fix Version/s 10.0.21 [ 19406 ]
            Fix Version/s 10.1.7 [ 19604 ]
            Fix Version/s 5.5.45 [ 19405 ]
            Fix Version/s 10.0 [ 16000 ]
            Fix Version/s 5.5 [ 15800 ]
            Resolution Fixed [ 1 ]
            Status Stalled [ 10000 ] Closed [ 6 ]
            svoj Sergey Vojtovich made changes -
            serg Sergei Golubchik made changes -
            Workflow MariaDB v3 [ 63775 ] MariaDB v4 [ 146318 ]

            People

              svoj Sergey Vojtovich
              f_razzoli Federico Razzoli
              Votes:
              0 Vote for this issue
              Watchers:
              5 Start watching this issue

              Dates

                Created:
                Updated:
                Resolved:

                Git Integration

                  Error rendering 'com.xiplink.jira.git.jira_git_plugin:git-issue-webpanel'. Please contact your Jira administrators.