问题现象
大并发执行SQL,报错"sorry, too many clients already";或报无法创建线程、无法 fork进程等错误。
原因分析
该类报错是由于操作系统线程资源不足引起,查看操作系统ulimit -u,如果过小(如 小于32768),则基本可以判断是操作系统限制引起的。
处理办法
通过ulimit -u查看操作系统max user processes的值。按如下简易公式计算需要设置的 小值为:value=max(32768, 实例数目*8192),其中实例数目指本节点所有CN、DN、GTM实 例总数。
[root@openGauss36 mnt]# ulimit -u
unlimited
[root@openGauss36 mnt]#
设置方法为,修改/etc/security/limits.conf,追加如下两行:
* hard nproc [value]
* soft nproc [value]
对于不同操作系统修改方式略有不同,centos6以上版本可以修改/etc/security/ limits.d/90-nofile.conf文件,方法同上。
另外,也可以直接通过ulimit -u [values]设置,但OS重启会失效,可以添加到全局环 境变量/etc/profile文件中使其生效。
在大并发模式下,建议开启线程池,使数据库内部的线程资源受控。
「喜欢这篇文章,您的关注和赞赏是给作者最好的鼓励」
关注作者
【版权声明】本文为墨天轮用户原创内容,转载时必须标注文章的来源(墨天轮),文章链接,文章作者等基本信息,否则作者和墨天轮有权追究责任。如果您发现墨天轮中有涉嫌抄袭或者侵权的内容,欢迎发送邮件至:contact@modb.pro进行举报,并提供相关证据,一经查实,墨天轮将立刻删除相关内容。
评论
文集目录
暂无数据