Deadlock detected while executing concurrent insert queries on same table

From: Sri Keerthi <ksri7840(at)gmail(dot)com>
To: pgsql-hackers(at)lists(dot)postgresql(dot)org
Subject: Deadlock detected while executing concurrent insert queries on same table
Date: 2025-03-31 14:03:47
Message-ID: CAGGQ0Y0Cm_NQWGnaWXQ4CX=pj64PDWFZW7m0p+8rinnDg524OA@mail.gmail.com
Views: Raw Message | Whole Thread | Download mbox | Resend email
Thread:
Lists: pgsql-hackers

Hello community,

I recently encountered a deadlock in postgresql while performing concurrent
INSERT statements on the same table in two separate sessions.

The error message explicitly mentions that the deadlock occurred while
inserting an index tuple.

There were no explicit transactions (BEGIN/COMMIT). The inserts were
executed as the standalone statements.

*PG version : 11.4*

Here’s the *table definition* :

Table “auditlog”

Column | Type | Collation | Nullable |
Default
------------------+-----------------------------+-----------+----------+---------
id | bigint | | not null |
audit_logid | bigint | | not null |
recordid | bigint | | |
recordname | text | | |
module | character varying(50) | | not null |
actioninfo | citext | | not null |
relatedid | bigint | | |
related_name | character varying(255) | | |
accountid | bigint | | |
accountname | character varying(255) | | |
doneby | character varying(255) | | not null |
userid | bigint | | |
audit_time | timestamp without time zone | | not null |
isauditlogdata | boolean | | not null |
details | citext | | |
auditcategory | integer | | not null |
operationtype | integer | | not null |
source | integer | | not null |

Indexes:
"auditlog_pkey" PRIMARY KEY, btree (id, audit_time, audit_logid)
"auditlog_idx1" btree (recordid)
"auditlog_idx2" btree (audit_logid DESC)
"auditlog_idx3" btree (userid)
"auditlog_idx4" btree (relatedid)
"auditlog_idx5" gist (actioninfo gist_trgm_ops)

and exact *error message* from the logs :

*ERROR*: INSERT failed, ERROR: deadlock detected

DETAIL: Process 3841267 waits for ShareLock on transaction
185820512; blocked by process 3841268.

Process 3841268 waits for ShareLock on transaction 185820513;
blocked by process 3841267.

HINT: See server log for query details.

CONTEXT: while inserting index tuple (31889,32) in relation
“auditlog”

*Insert Query1 :*
INSERT INTO
auditlog (ID,AUDIT_LOGID,RECORDID,RECORDNAME,MODULE,ACTIONINFO,RELATEDID,RELATED_NAME,ACCOUNTID,ACCOUNTNAME,DONEBY,USERID,AUDIT_TIME,ISAUDITLOGDATA,DETAILS,AUDITCATEGORY,OPERATIONTYPE,SOURCE)
VALUES ($1,$2,$3,$4,$5,$6,$7,$8,$9,$10,$11,$12,$13,$14,$15,$16,$17,$18)

*Insert Query2 :*
INSERT INTO auditlog (id, audit_logid, recordid, recordname, module,
actioninfo, relatedid, related_name, accountid, accountname, doneby,
userid, audit_time, isauditlogdata, details, auditcategory, operationtype,
source) VALUES ('67016721806'::bigint, '389760000328846849'::bigint,
NULL::bigint, NULL::text, 'Tasks'::character varying(50),
'Deleted'::citext, NULL::bigint, NULL::character varying(255),
NULL::bigint, NULL::character varying(255), 'Technologies'::character
varying(255), '3470005430253334'::bigint, '2024-03-24 14:39:06'::timestamp
without time zone, true, NULL::citext, 0, 11, 20)

Could this be a bug, or is it expected behaviour under certain conditions ?

I was unable to reproduce this issue again. Any insights or guidance on how
to analyse this further would be greatly appreciated.

Regards,

Sri Keerthi.
ReplyForward
Add reaction

Browse pgsql-hackers by date

  From Date Subject
Next Message Christoph Berg 2025-03-31 14:06:49 Re: [PoC] Federated Authn/z with OAUTHBEARER
Previous Message Andrew Dunstan 2025-03-31 13:57:56 Re: Non-text mode for pg_dumpall