openGauss学习笔记209 openGauss 数据库运维常见故障定位案例共享内存泄露问题

2024年 6月 1日 45.2k 0

Table of Contents

    • openGauss学习笔记-209 openGauss 数据库运维-常见故障定位案例-共享内存泄露问题
      • 209.1 共享内存泄露问题
        • 209.1.1 问题现象
        • 209.1.2 原因分析
        • 209.1.3 处理方法

openGauss学习笔记-209 openGauss 数据库运维-常见故障定位案例-共享内存泄露问题

209.1 共享内存泄露问题

209.1.1 问题现象

日志里出现如下错误:

This error usually means that PostgreSQL's request for a shared memory segment
exceeded available memory or swap space, or exceeded your kernel's SHMALL parameter.
You can either reduce the request size or reconfigure the kernel with larger SHMALL.

209.1.2 原因分析

使用free命令查看内存使用情况,发现shared内存的确占用了很大一部分。

# free -g
total used free shared buff/cache available
Mem: 31 1 2 23 27 2
Swap: 3 3 0

使用ipcs命令进一步查看共享内存的使用情况,发现存在大量不再被进程使用但未回收的共享内存,即nattch为0的部分。

[root@pekpeuler00671 script]# ipcs -m

------ Shared Memory Segments --------
key shmid owner perms bytes nattch status
0x00000000 65536 gnome-init 777 16384 1 dest
0x00000000 131073 gnome-init 777 16384 1 dest
0x00000000 163842 gnome-init 777 3145728 2 dest
0x00000000 393219 gnome-init 600 524288 2 dest
0x00000000 425988 gnome-init 600 4194304 2 dest
0x00000000 458757 gnome-init 777 3145728 2 dest
0x00f42401 3604486 1001 600 4455342080 0
0x00f42402 14123015 1003 600 4457177088 0
0x00f42403 23592968 1005 600 4457177088 0
0x00f42404 33062921 1007 600 4457177088 0
0x00f42405 42532874 1009 600 4457177088 0
0x00f42406 52002827 1011 600 4457177088 0
0x00f42407 61472780 1013 600 4457177088 0
0x00f42408 70942733 1015 600 4457177088 0
0x00f42409 80412686 1017 600 4457177088 0
0x00f4240a 89882639 1019 600 4457177088 0
0x00f4240b 99352592 1021 600 4457177088 0
0x00f4240c 108822545 1023 600 4457177088 0
0x00f4240d 118292498 1025 600 4457177088 0
0x00f4240e 127762451 1027 600 4457177088 0
0x00f4240f 136904724 1029 600 4455342080 0
0x00f42410 146374677 1031 600 4457177088 0
0x00f42411 155844630 1033 600 4457177088 0
0x00f42412 165314583 1035 600 4457177088 0
0x00f42413 174784536 1037 600 4457177088 0

经过定位,这部分内存是由于使用kill -9命令来退出数据库进程,导致没有调用IpcMemoryDelete函数来清理共享内存,造成了内存泄漏。

209.1.3 处理方法

使用ipcrm释放无属主的共享内存,例如,释放shmid3604486的共享内存,命令如下所示。

ipcrm -m 3604486

👍 点赞,你的认可是我创作的动力!

⭐️ 收藏,你的青睐是我努力的方向!

✏️ 评论,你的意见是我进步的财富!

openGauss学习笔记-209 openGauss 数据库运维-常见故障定位案例-共享内存泄露问题-1

相关文章

Oracle如何使用授予和撤销权限的语法和示例
Awesome Project: 探索 MatrixOrigin 云原生分布式数据库
下载丨66页PDF,云和恩墨技术通讯(2024年7月刊)
社区版oceanbase安装
Oracle 导出CSV工具-sqluldr2
ETL数据集成丨快速将MySQL数据迁移至Doris数据库

发布评论