• 数据库使用psql及jdbc进行远程连接,不定时自动断开的解决办法


    瀚高数据库
    目录
    环境
    症状
    问题原因
    解决方案

    环境
    系统平台:Linux x86-64 Red Hat Enterprise Linux 7,Linux x86-64 Red Hat Enterprise Linux 6,银河麒麟U系(CPU飞腾)4
    版本:4.5
    症状
    瀚高数据库在使用psql工具以及jdbc进行远程连接时,在经过一定时间之后报错-致命错误:

    terminating connection due to client no input timeout。
    
    排查安全参数,hg_clientnoinput = 0
    • 1
    • 2
    • 3

    问题原因
    操作系统TCP相关参数设置不正确,数据库沿用操作系统配置,导致TCP保活机制未生效。

    解决方案
    数据库做如下配置后,问题解决:

    #以下参数默认值都为0,表示延用服务器的配置情况。

    tcp_keepalives_idle = '60'
    
    tcp_keepalives_interval = '20'
    
    tcp_keepalives_count = '10'
    
    • 1
    • 2
    • 3
    • 4
    • 5

    参数相关说明:

    tcp_keepalives_idle (integer)

    规定在操作系统向客户端发送一个TCP keepalive消息后无网络活动的时间总量。 如果指定值时没有单位,则以秒为单位。值0(默认值)表示选择操作系统默认值。 指定不活动多少秒之后通过 TCP 向客户端发送一个 keepalive 消息。 0 值表示使用默认值。 这个参数只有在支持TCP_KEEPIDLE或等效套接字选项的系统或 Windows 上才可以使用。在其他系统上,它必须为零。在通过 Unix 域套接字连接的会话中,这个参数被忽略并且总是读作零。

    tcp_keepalives_interval (integer)

    规定未被客户端确认收到的TCP keepalive消息应重新传输的时间长度。 如果指定值时没有单位,则以秒为单位。值0(默认值)表示选择操作系统默认值。 这个参数只有在支持TCP_KEEPINTVL或等效套接字选项的系统或 Windows 上才可以使用。在其他系统上,必须为零。在通过 Unix域套接字连接的会话中,这个参数被忽略并总被读作零。

    tcp_keepalives_count (integer)
    指定服务器到客户端的连接被认为中断之前可以丢失的TCP keepalive消息的数量。值0(默认值)表示选择操作系统默认值。 这个参数只有在支持TCP_KEEPCNT或等效套接字选项的系统上才可以使用。在其他系统上,必须为零。在通过 Unix 域套接字连接的会话中,这个参数被忽略并总被读作零。

    tcp_user_timeout (integer)
    指定传输的数据在TCP连接被强制关闭之前可以保持未确认状态的时间量。 如果指定值时没有单位,则以毫秒为单位。值0(默认值)表示选择操作系统默认值。 这个参数只有在支持TCP_USER_TIMEOUT的系统上才被支持;在其他系统上,它必须为零。 在通过Unix-domain 套接字连接的会话中,此参数将被忽略并且始终读取为零。

    服务器中相关的配置信息的方法:

    [root@Server3 ~]# cat /proc/sys/net/ipv4/tcp_keepalive_time
    [root@Server3 ~]# cat /proc/sys/net/ipv4/tcp_keepalive_intvl
    
    [root@Server3 ~]# cat /proc/sys/net/ipv4/tcp_keepalive_probes
    
    • 1
    • 2
    • 3
    • 4
  • 相关阅读:
    文心一言 VS 讯飞星火 VS chatgpt (139)-- 算法导论11.4 3题
    合成事件在san.js中的应用
    C++-逆向分析-IDA-IDC脚本-修改指定地址的函数名-函数重命名
    【JavaSE】接口
    微信小游戏怎么做?
    AI视界周刊第 1 期:最具性价比 GPT-4o mini 发布、大模型集体失智、语言模型安全漏洞
    修复mongodb未授权访问漏洞(漏洞编号:009711D8)
    雷电模拟器上使用第一个frida(二)之su超级权限
    【PyTorch深度学习项目实战100例】—— 基于AlexNet实现宠物小精灵(宝可梦)分类任务 | 第49例
    【算法练习Day11】滑动窗口最大值&&前 K 个高频元素
  • 原文地址:https://blog.csdn.net/pg_hgdb/article/details/125989665