[
https://issues.apache.org/jira/browse/THRIFT-966?page=com.atlassian.jira.plugin.system.issuetabpanels:comment-tabpanel&focusedCommentId=12978945#action_12978945
]
Ivan Murashko commented on THRIFT-966:
--------------------------------------
The getBindPort() method should be called exactly after TServerSocket::listen()
call. In other case the return value will be -1 (same as in the constructor).
Somebody can use spin-lock to wait until the value become greater than 0 but in
my case I used TServerEventHandler::preServe() hook to retrieve the real port
number and store it at a shared place where client can find it. The solution
worked without any issues for me.
> Bind to zero port
> -----------------
>
> Key: THRIFT-966
> URL: https://issues.apache.org/jira/browse/THRIFT-966
> Project: Thrift
> Issue Type: Improvement
> Components: C++ - Library
> Reporter: Ivan Murashko
> Fix For: 0.7
>
> Attachments: bindinfo_retrieval.diff
>
> Original Estimate: 1h
> Remaining Estimate: 1h
>
> apache::thrift::transport::TServerSocket class has a possibility to set 0 as
> port number. In this case bind will assign a free port number. Unfortunately
> there is no possibility to retrieve the assigned port number from the
> TServerSocket class. Thus clients will not be able to connect the server.
> The suggested patch introduces
> apache::thrift::transport::TServerSocket::getBindPort() method that return
> the assigned port number or -1 in the case of any failure or when the port
> has not been assigned yet.
--
This message is automatically generated by JIRA.
-
You can reply to this email to add a comment to the issue online.