openGauss学习笔记206 openGauss 数据库运维常见故障定位案例too many clients already

2024年 5月 18日 72.2k 0

Table of Contents

    • openGauss学习笔记-206 openGauss 数据库运维-常见故障定位案例-too many clients already
      • 206.1 高并发报错“too many clients already”或无法创建线程
        • 206.1.1 问题现象
        • 206.1.2 原因分析
        • 206.1.3 处理办法

openGauss学习笔记-206 openGauss 数据库运维-常见故障定位案例-too many clients already

206.1 高并发报错“too many clients already”或无法创建线程

206.1.1 问题现象

高并发执行SQL,报错“sorry, too many clients already”;或报无法创建线程、无法fork进程等错误。

206.1.2 原因分析

该类报错是由于操作系统线程资源不足引起,查看操作系统ulimit -u,如果过小(例如小于32768),则基本可以判断是操作系统限制引起的。

206.1.3 处理办法

通过“ulimit -u”命令查看操作系统max user processes的值。

[root@openGauss36 mnt]# ulimit -u
unlimited

按如下简易公式计算需要设置的最小值。

value=max(32768,实例数目*8192)

其中实例数目指本节点所有实例总数。

设置最小值方法为,修改/etc/security/limits.conf,追加如下两行:

* hard nproc [value]
* soft nproc [value]

对于不同操作系统修改方式略有不同,centos6以上版本可以修改/etc/security/limits.d/90-nofile.conf文件,方法同上。

另外,也可以直接通过如下命令设置,但OS重启会失效,可以添加到全局环境变量/etc/profile文件中使其生效。

ulimit -u [values]

在大并发模式下,建议开启线程池,使数据库内部的线程资源受控。

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

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

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

openGauss学习笔记-206 openGauss 数据库运维-常见故障定位案例-too many clients already-1

相关文章

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

发布评论