【发布时间】:2019-07-09 14:18:36
【问题描述】:
共享内存文件在 Postgres 11 中被删除一段时间(约 15 小时)
2019-07-09 08:46:41 CDT [] [6723]: [1-1] user=,db=,e=58P01 ERROR: could not open shared memory segment "/PostgreSQL.291691635": No such file or directory
2019-07-09 08:46:41 CDT [] [6722]: [1-1] user=,db=,e=58P01 ERROR: could not open shared memory segment "/PostgreSQL.291691635": No such file or directory
2019-07-09 08:46:41 CDT [10.40.0.204(60550)] [13880]: [1-1] user=user_name,db=db_name,e=58P01 ERROR: could not open shared memory segment "/PostgreSQL.291691635": No such file or directory
2019-07-09 08:46:41 CDT [10.40.0.204(60550)] [13880]: [2-1] user=user_name,db=db_name,e=58P01 CONTEXT: parallel worker
2019-07-09 08:46:41 CDT [10.40.0.204(60550)] [13880]: [3-1] user=user_name,db=db_name,e=58P01 STATEMENT: WITH overall_reviewed AS (SQL Query)
GCP 虚拟机配置
CPU: 4
RAM: 16 GB
OS: Ubuntu 18.04.1 LTS
内核共享内存设置shared
kernel.shmmax=8589934592
kernel.shmall=2097152
postgresql.config
max_connections = 500
shared_buffers = 4GB
effective_cache_size = 12GB
maintenance_work_mem = 1GB
checkpoint_completion_target = 0.7
wal_buffers = 16MB
default_statistics_target = 100
random_page_cost = 1.1
effective_io_concurrency = 200
work_mem = 4194kB
min_wal_size = 1GB
max_wal_size = 2GB
max_worker_processes = 4
max_parallel_workers_per_gather = 2
max_parallel_workers = 4
启动期间:没有错误/警告
大约 15 小时后,一些共享内存文件被删除,我怀疑是否还有其他进程正在删除“/dev/shm”中的文件?
不知道根本原因是什么
【问题讨论】:
-
您找到解决方案了吗?我在我的 OpenBSD postgresql 设置中也随机遇到了这个问题。每隔一两周,它就会随机出现在连接到数据库的客户端之一上。发生这种情况时,postgresql 仍然可以正常工作,只需重新启动客户端就足以让事情继续工作一周左右。
-
在 postgresql.conf 中设置 dynamic_shared_memory_type = none 确实解决了这个问题。
-
这个问题有什么新的解决方案@n1000 吗?
"none"似乎不再是dynamic_shared_memory_type的选项。
标签: postgresql systemd ubuntu-18.04 postgresql-11