PostgreSQL修改最大连接数的详细操作步骤

 更新时间:2025年06月11日 11:04:14   作者:IT后浪  
PostgreSQL连接数超限导致错误,需修改max_connections参数及操作系统ulimit限制,这篇文章主要介绍了PostgreSQL修改最大连接数的详细操作步骤,需要的朋友可以参考下

前言

在使用PostgreSQL 的时候,经常会遇到这样的错误提示, sorry, too many clients already,这是因为默认PostgreSQL最大连接数是 100, 一般情况下,个人使用时足够的,但是在生产环境,这个连接数是远远不够的;

修改最大连接数

要修改 PostgreSQL 的最大连接数,可以按照以下步骤进行操作:

打开PostgreSQL配置文件

配置文件的路径可能因操作系统和 PostgreSQL 版本而异。以下是一些常见的配置文件路径:

  • Ubuntu/Debian:/etc/postgresql/<version>/main/postgresql.conf
  • CentOS/RHEL:/var/lib/pgsql/<version>/data/postgresql.conf
  • macOS Homebrew 安装:/usr/local/var/postgres/postgresql.conf

打开配置文件并找到 max_connections 参数。

修改最大连接数

在配置文件中找到 max_connections 参数,并将其值修改为所需的最大连接数。例如,将最大连接数设置为 1000,可以将以下行添加到配置文件中:

max_connections = 1000

保存配置文件。

重启 PostgreSQL 服务

保存配置文件后,需要重启 PostgreSQL 服务才能使修改生效。

可以使用以下命令重启 PostgreSQL 服务:

sudo service postgresql restart

或者,根据不同的操作系统和安装方式,可能需要使用其他命令来重启 PostgreSQL 服务。

如果是使用Docker 的方式启动的 PostgreSQL , 需要通过一下命令重启 Docker 服务:

docker restart <postgresql_docker_name>

验证修改是否生效

重启 PostgreSQL 服务后,可以使用以下命令来验证最大连接数是否已经修改:

psql -U <username> -c "SHOW max_connections;"

将 <username> 替换为实际的 PostgreSQL 用户名。该命令将显示当前的最大连接数。

如果可以通过Navicat直接连接到 PostgreSQL ,可以直接新建查询窗口查询:

SHOW max_connections;

请注意,修改最大连接数可能会影响系统的性能和资源使用情况。在增加最大连接数之前,请确保系统具有足够的资源来支持所需的连接数,并考虑数据库服务器的硬件配置和负载情况。

修改操作系统文件描述符限制

在某些情况下,可能存在其他配置项的限制,导致 max_connections 的修改不生效。例如,操作系统的文件描述符限制(ulimit)可能会限制 PostgreSQL 的最大连接数。

可以通过以下命令查看当前的文件描述符限制:

ulimit -n

如果文件描述符限制较低,可以尝试增加限制。具体的操作方法可以参考操作系统的文档或相关资源。

要修改操作系统的 ulimit 最大值,可以按照以下步骤进行操作:

查看当前的 ulimit 最大值

可以使用以下命令查看当前的 ulimit 最大值:

ulimit -a

这将显示当前的 ulimit 配置,包括最大文件描述符数、最大用户进程数等。

临时修改 ulimit 最大值

可以使用以下命令临时修改 ulimit 最大值:

ulimit -n <new_value>

其中 <new_value> 是要设置的新的最大值。例如,要将最大文件描述符数设置为 65536;

可以运行以下命令:

ulimit -n 65536

注意,这种方式修改的最大值只在当前会话中有效,重新登录后将恢复为默认值。

永久修改 ulimit 最大值

要永久修改 ulimit 最大值,需要编辑系统的配置文件。具体的配置文件路径可能因操作系统而异。以下是一些常见的配置文件路径:

  • Ubuntu/Debian:/etc/security/limits.conf
  • CentOS/RHEL:/etc/security/limits.conf
  • macOS:/etc/launchd.conf

打开配置文件,并添加或修改以下行:

* hard nofile <new_value>
* soft nofile <new_value>
* hard nproc <new_value>
* soft nproc <new_value>

其中 <new_value> 是要设置的新的最大值。

例如,所有用户的硬/软限制(soft limit)文件描述符数设置为 65536,所有用户的硬/软限制进程数设置为 65536,可以添加以下行:

* hard nofile 65536
* soft nofile 65536
* hard nproc 65536
* soft nproc 65536

* 代表针对所有用户

noproc 是代表最大进程数

nofile 是代表最大文件打开数

  • 保存文件并重新启动系统,使修改生效:

    reboot
    
  • 验证修改是否生效:

    重新登录系统后,可以再次运行 ulimit -n 命令来验证修改是否生效。确保最大值已经更新为所设置的新值。

请注意,修改操作系统的 ulimit 最大值可能需要管理员权限。在进行任何系统级别的修改之前,请确保了解修改的影响,并备份重要的配置文件。

查询数据库连接情况

除以上使用 SHOW max_connections; 查看PostgreSQL的最大连接数, 这里也整理了一些常用的

查询数据库配置的最大连接数

select setting from pg_catalog.pg_settings where "name" ='max_connections';

查询数据库当前连接信息

select datname ,pid ,usename ,query_start ,wait_event ,wait_event_type ,state ,query from pg_catalog.pg_stat_activity order by query_start desc ;

根据进程 ID 取消正在执行的查询

select pg_cancel_backend(pid);

根据进程 ID 终止指定的连接

select pg_terminate_backend(pid);

根据进程 ID 获取连接的详细信息

select pg_stat_get_activity(pid);

查询当前使用的连接数

select count(*) from pg_catalog.pg_stat_activity ;

查询当前空余连接数

select setting::int2 -(select count(*) from pg_catalog.pg_stat_activity) from pg_catalog.pg_settings where "name" ='max_connections';

总结 

到此这篇关于PostgreSQL修改最大连接数的文章就介绍到这了,更多相关PostgreSQL最大连接数修改内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • PostgreSQL教程(四):数据类型详解

    PostgreSQL教程(四):数据类型详解

    这篇文章主要介绍了PostgreSQL教程(四):数据类型详解,本文讲解了数值类型、字符类型、布尔类型、位串类型、数组、复合类型等数据类型,需要的朋友可以参考下
    2015-05-05
  • DBeaver中PostgreSQL数据库显示不全的解决方法

    DBeaver中PostgreSQL数据库显示不全的解决方法

    最近,在DBeaver中连接了本地的PostgreSQL数据库,但是连接后打开这个数据库时发现,数据库显示不全,所以本文给大家介绍了DBeaver中PostgreSQL数据库显示不全的解决方法,需要的朋友可以参考下
    2024-11-11
  • pgsql之pg_stat_replication的使用详解

    pgsql之pg_stat_replication的使用详解

    这篇文章主要介绍了pgsql之pg_stat_replication的使用详解,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2021-01-01
  • PostgreSQL批量update与oracle差异详解

    PostgreSQL批量update与oracle差异详解

    这篇文章主要介绍了PostgreSQL批量update与oracle差异,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2021-01-01
  • postgreSQL数据库的监控及数据维护操作

    postgreSQL数据库的监控及数据维护操作

    这篇文章主要介绍了postgreSQL数据库的监控及数据维护操作,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2021-01-01
  • 解决PostgreSQL数据库连接报错:psql: error: FATAL: password authentication failed for user "postgres"

    解决PostgreSQL数据库连接报错:psql: error: FATAL: password authent

    这篇文章主要给大家介绍了关于如何解决PostgreSQL数据库连接报错:psql: error: FATAL: password authentication failed for user "postgres"的相关资料,在使用PostgreSQL时,一些关键配置的错误可能导致数据库无法正常启动,需要的朋友可以参考下
    2024-05-05
  • PostgreSQL存储过程用法实战详解

    PostgreSQL存储过程用法实战详解

    这篇文章主要介绍了PostgreSQL存储过程用法,结合具体实例详细分析了PostgreSQL数据库存储过程的定义、使用方法及相关操作注意事项,并附带一个完整实例供大家参考,需要的朋友可以参考下
    2018-08-08
  • 基于PostgreSQL/openGauss 的分布式数据库解决方案

    基于PostgreSQL/openGauss 的分布式数据库解决方案

    ShardingSphere-Proxy 作为透明数据库代理,用户无需关心 Proxy 如何协调背后的数据库。今天通过本文给大家介绍基于PostgreSQL/openGauss 的分布式数据库解决方案,感兴趣的朋友跟随小编一起看看吧
    2021-12-12
  • PostgreSQL时间日期的语法及注意事项

    PostgreSQL时间日期的语法及注意事项

    在开发过程中,经常要取日期的年,月,日,小时等值,PostgreSQL 提供一个非常便利的EXTRACT函数,这篇文章主要给大家介绍了关于PostgreSQL时间日期的语法及注意事项的相关资料,需要的朋友可以参考下
    2023-01-01
  • postgres主备切换之文件触发方式详解

    postgres主备切换之文件触发方式详解

    这篇文章主要介绍了postgres主备切换之文件触发方式详解,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2020-12-12

最新评论