首页
学习
活动
专区
工具
TVP
发布
社区首页 >问答首页 >未记录的表上的WALWriteLock

未记录的表上的WALWriteLock
EN

Stack Overflow用户
提问于 2018-08-18 00:04:25
回答 2查看 3.3K关注 0票数 2

我们在连接到postgres数据库的pgbouncer上遇到了一些连接峰值。当我们在这些峰值期间查询pg_stat_activity时,我们会看到大量使用wait_event WALWriteLock的活动查询。

我们将一些高度插入的表改成了未记录的,但是在峰值期间,插入到这些表中的内容仍然显示为wait_eventWALWriteLock。我认为如果一个表没有日志记录,那么inserts就不会在等待WALWriteLock时被占用。怎么回事?

此外,有没有关于如何阻止这些峰值的建议?

EN

回答 2

Stack Overflow用户

发布于 2019-06-06 03:13:44

WALWriteLock:在WAL记录刷新到磁盘时或在WAL段切换期间由PostgreSQL进程累积。synchronous_commit=off消除了等待磁盘刷新的时间,full_page_writes=off减少了要刷新的数据量。你可以尝试上面在12月提到的:- https://www.percona.com/blog/2018/10/30/postgresql-locking-part-3-lightweight-locks/

票数 0
EN

Stack Overflow用户

发布于 2020-12-08 16:41:47

一个可能的答案是,尽管没有将表本身写入WAL,但提交仍然写入WAL,如果您进行了大量的小事务,则可能会出现这种情况。看看是否可以将插入分组到较少数量的事务中。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/51899230

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档