我正在检查一个运行在heroku中的应用程序的锁定日志,它显示了来自延迟作业和增量计数器的这么多锁,而且这一次我得到了这么多超时

sql_error_code = 00000 LOG: process 129728 still waiting for ShareLock on
transaction 1296511670 after 1000.149 ms

2017-06-02T16:24:58+00:00 app
postgres.129728 - - [TEST] [7-2] sql_error_code = 00000 DETAIL: Process
holding the lock: 129457. Wait queue: 129728.

02 Jun 2017 20:24:58.338198 <134>1 2017-06-02T16:24:58+00:00 app
postgres.129728 - - [TEST] [7-3] sql_error_code = 00000 CONTEXT: while
locking tuple (75,2) in relation "delayed_jobs"

LOG: process 129429 acquired ExclusiveLock on tuple (878044,83) of relation
16953 of database 16385 after 3220.356 ms

02 Jun 2017 20:24:58.338591 <134>1 2017-06-02T16:24:58+00:00 app
postgres.129728 - - [TEST] [7-4] sql_error_code = 00000 STATEMENT: UPDATE
"delayed_jobs" SET locked_at = '2017-06-02 16:24:57.033870', locked_by =
'host:a96aff72dae123123e pid:4' WHERE id IN (SELECT id FROM
"delayed_jobs" WHERE ((run_at <= '2017-06-02 16:24:57.032776' AND (locked_at
IS NULL OR locked_at < '2017-06-02 12:24:57.032817') OR locked_by =
'host:a96aff72dae123123e pid:4') AND failed_at IS NULL)
ORDER BY priority ASC, run_at ASC LIMIT 1 FOR UPDATE) RETURNING *

 sql_error_code = 00000 DETAIL: Process holding the lock: 129495. Wait queue:
 3276.

 02 Jun 2017 20:25:09.279197 <134>1 2017-06-02T16:25:08+00:00 app
 postgres.3276
 - - [TEST] [7-3] sql_error_code = 00000 CONTEXT: while updating tuple
 (878034,120) in relation "messages"


 02 Jun 2017 20:25:09.279248 <134>1 2017-06-02T16:25:08+00:00 app
 postgres.3276
 - - [TEST] [7-4] sql_error_code = 00000
 STATEMENT: UPDATE "messages" SET
 "item_no" = COALESCE("item_no", 0) + 1 WHERE "messages"."id" =
 48290879

我想这不是普通的锁,有没有办法修这种锁?

最佳答案

我不知道你认为“普通”锁是什么。当多个事务试图同时更新(或select for update)同一元组时,这是您获得的普通锁。
但是,为什么带着这些锁的事务至少会保持一秒钟呢?交易本身是缓慢的,还是分散了注意力?

09-10 16:05