shinsunwoo created HIVE-23581:
---------------------------------
Summary: On service discovery mode, the initial port of
hiveserver2 to which zookeeper is applied is not changed.
Key: HIVE-23581
URL: https://issues.apache.org/jira/browse/HIVE-23581
Project: Hive
Issue Type: Bug
Components: JDBC
Affects Versions: All Versions
Reporter: shinsunwoo
When accessing hiveserver2 with
`hive.server2.support.dynamic.service.discovery` and`
hive.server2.limit.connections.per.user` applied through the hive jdbc driver,
The jdbc driver is a method of randomly obtaining domain information (host,
port) information of hivesever2 registered in the zookeeper.
However, if the hiveserver2 obtained from the zookeeper first fails to connect
due to the setting value of `hive.server2.limit.connections.per.user`, the port
will not be initialized due to the following code logic.
*
https://github.com/apache/hive/blob/8443e50fdfa284531300f3ab283a7e4959dba623/jdbc/src/java/org/apache/hive/jdbc/ZooKeeperHiveClientHelper.java#L320
{code:java}
if ((matcher.group(1).equals("hive.server2.thrift.http.port"))
&& !(connParams.getPort() > 0)) {
connParams.setPort(Integer.parseInt(matcher.group(2)));
}
{code}
Therefore, if the port of the next accessible hiveserver2 is not the first
port, a problem occurs.
So I modified the port number to be initialized to "-1" whenever the update
function (updateConnParamsFromZooKeeper) is executed.
--
This message was sent by Atlassian Jira
(v8.3.4#803005)