Java自学者论坛

 找回密码
 立即注册

手机号码,快捷登录

恭喜Java自学者论坛(https://www.javazxz.com)已经为数万Java学习者服务超过8年了!积累会员资料超过10000G+
成为本站VIP会员,下载本站10000G+会员资源,会员资料板块,购买链接:点击进入购买VIP会员

JAVA高级面试进阶训练营视频教程

Java架构师系统进阶VIP课程

分布式高可用全栈开发微服务教程Go语言视频零基础入门到精通Java架构师3期(课件+源码)
Java开发全终端实战租房项目视频教程SpringBoot2.X入门到高级使用教程大数据培训第六期全套视频教程深度学习(CNN RNN GAN)算法原理Java亿级流量电商系统视频教程
互联网架构师视频教程年薪50万Spark2.0从入门到精通年薪50万!人工智能学习路线教程年薪50万大数据入门到精通学习路线年薪50万机器学习入门到精通教程
仿小米商城类app和小程序视频教程深度学习数据分析基础到实战最新黑马javaEE2.1就业课程从 0到JVM实战高手教程MySQL入门到精通教程
查看: 926|回复: 0

HiveServer2连接ZooKeeper出现Too many connections问题的解决

[复制链接]
  • TA的每日心情
    奋斗
    2 小时前
  • 签到天数: 804 天

    [LV.10]以坛为家III

    2053

    主题

    2111

    帖子

    72万

    积分

    管理员

    Rank: 9Rank: 9Rank: 9

    积分
    726782
    发表于 2021-4-25 05:04:54 | 显示全部楼层 |阅读模式

    作者: 大圆那些事 | 文章可以转载,请以超链接形式标明文章原始出处和作者信息

    网址: http://www.cnblogs.com/panfeng412/archive/2013/03/23/hiveserver2-too-many-zookeeper-connections-issues.html

    HiveServer2支持多客户端的并发访问,使用ZooKeeper来管理Hive表的读写锁。实际环境中,遇到了HiveServer2连接ZooKeeper出现Too many connections的问题,这里是对这一问题的排查和解决过程。

    问题描述

    HiveServer2服务无法执行hive命令,日志中提示如下错误:

    2013-03-22 12:54:43,946 WARN  zookeeper.ClientCnxn (ClientCnxn.java:run(1089)) - Session 0x0 for server hostname/***.***.***.***:2181, unexpected error, closing socket connection and attempting reconnect
    java.io.IOException: Connection reset by peer
            at sun.nio.ch.FileDispatcher.read0(Native Method)
            at sun.nio.ch.SocketDispatcher.read(SocketDispatcher.java:21)
            at sun.nio.ch.IOUtil.readIntoNativeBuffer(IOUtil.java:233)
            at sun.nio.ch.IOUtil.read(IOUtil.java:200)
            at sun.nio.ch.SocketChannelImpl.read(SocketChannelImpl.java:236)
            at org.apache.zookeeper.ClientCnxnSocketNIO.doIO(ClientCnxnSocketNIO.java:68)
            at org.apache.zookeeper.ClientCnxnSocketNIO.doTransport(ClientCnxnSocketNIO.java:355)
            at org.apache.zookeeper.ClientCnxn$SendThread.run(ClientCnxn.java:1068)

    问题排查

    1. 首先,根据HiveServer2的错误日志,提示是由于Connection reset by peer,即连接被ZooKeeper拒绝。

    2. 进一步查看HiveServer2上所配置的ZooKeeper集群日志(用户Hive表的读写锁管理),发现如下错误信息:

    2013-03-22 12:52:48,938 [myid:] - WARN  [NIOServerCxn.Factory:0.0.0.0/0.0.0.0:2181:NIOServerCnxnFactory@193] - Too many connections from /***.***.***.*** - max is 50

    3. 结合HiveServer2的日志,可见是由于HiveServer2所在机器对ZooKeeper的连接数超过了ZooKeeper设置允许的单个client最大连接数(这里是50)。

    4. 我们进一步确认了是不是完全都是HiveServer2占用了这50个连接,显示确实是HiveServer2进程内部占用了这50个连接(进程号26871即为HiveServer2进程):

    [user@hostname ~]$ sudo netstat -nap  | grep 2181
    tcp    0      0 ***.***.***.***:58089   ***.***.***.***:2181    ESTABLISHED 26871/java          
    tcp    0      0 ***.***.***.***:57837   ***.***.***.***:2181    ESTABLISHED 26871/java          
    tcp    0      0 ***.***.***.***:57853   ***.***.***.***:2181    ESTABLISHED 26871/java         
    ……
    (共计50个)

    5. 为什么HiveServer2会占用这么多连接?而实际并发请求量并没有这么多。只能从HiveServer2的实现原理找找线索,由于HiveServer2是通过Thrift实现的,怀疑是不是其内部维护连接池导致的?经过查看hive-default.xml中发现,其中默认配置了工作线程数(这里猜测每个工作线程会维护一个与ZooKeeper的连接,有待从代码级别进行验证)

    <property>
      <name>hive.server2.thrift.min.worker.threads</name>
      <value>5</value>
      <description>Minimum number of Thrift worker threads</description>
    </property>
    <property>
      <name>hive.server2.thrift.max.worker.threads</name>
      <value>100</value>
      <description>Maximum number of Thrift worker threads</description>
    </property>

    问题解决

    方法一:

    通过在hive-site.xml中修改HiveServer2Thrift工作线程数,减少与ZooKeeper的连接请求数。这样可能降低HiveServer2的并发处理能力。

    方法二:

    通过修改ZooKeeperzoo.cfg文件中的maxClientCnxns选项,调大对于单个Client的连接数限制。

    以上两个方法,需要根据自己的实际生产情况进行合理设置。

    相关的配置选项:

    1hive-site.xml中:

    <property>
      <name>hive.server2.thrift.min.worker.threads</name>
      <value>10</value>
      <description>Minimum number of Thrift worker threads</description>
    </property>
    <property>
      <name>hive.server2.thrift.max.worker.threads</name>
      <value>200</value>
      <description>Maximum number of Thrift worker threads</description>
    </property>
    <property>
      <name>hive.zookeeper.session.timeout</name>
      <value>60000</value>
      <description>Zookeeper client's session timeout. The client is disconnected, and as a result, all locks released, if a heartbeat is not sent in the timeout.</description>
    </property>

    2zoo.cfg中:

    # Limits the number of concurrent connections (at the socket level) that a single client, identified by IP address
    maxClientCnxns=200
    # The minimum session timeout in milliseconds that the server will allow the client to negotiate
    minSessionTimeout=1000
    # The maximum session timeout in milliseconds that the server will allow the client to negotiate
    maxSessionTimeout=60000
    哎...今天够累的,签到来了1...
    回复

    使用道具 举报

    您需要登录后才可以回帖 登录 | 立即注册

    本版积分规则

    QQ|手机版|小黑屋|Java自学者论坛 ( 声明:本站文章及资料整理自互联网,用于Java自学者交流学习使用,对资料版权不负任何法律责任,若有侵权请及时联系客服屏蔽删除 )

    GMT+8, 2024-11-24 18:23 , Processed in 2.049043 second(s), 29 queries .

    Powered by Discuz! X3.4

    Copyright © 2001-2021, Tencent Cloud.

    快速回复 返回顶部 返回列表