You are viewing a plain text version of this content. The canonical link for it is here.
Posted to dev@reef.apache.org by "Seokchan Ahn (JIRA)" <ji...@apache.org> on 2017/07/02 12:02:01 UTC
[jira] [Commented] (REEF-1808) Fix lack of tcp port error in
NettyMessagingTransport
[ https://issues.apache.org/jira/browse/REEF-1808?page=com.atlassian.jira.plugin.system.issuetabpanels:comment-tabpanel&focusedCommentId=16071611#comment-16071611 ]
Seokchan Ahn commented on REEF-1808:
------------------------------------
This method generates a bug on current version(0.16.0).
{{AddressComparator}} class in {{LegacyLocalAddressProvider}} implements {{Comparator}} but doesn't implements {{Serializable}} and it occurs {{SE_COMPARATOR_SHOULD_BE_SERIALIZABLE}} bug.
I resolved this issue by just let the {{AddressComparator}} implements {{Serializable}} as well.
> Fix lack of tcp port error in NettyMessagingTransport
> -----------------------------------------------------
>
> Key: REEF-1808
> URL: https://issues.apache.org/jira/browse/REEF-1808
> Project: REEF
> Issue Type: Bug
> Components: Wake
> Environment: Java
> Reporter: Sanha Lee
> Priority: Minor
>
> The constructor of {{NettyMessagingTransport}} occasionally spits some exception saying there is no available TCP port, depending on the network environment.
> This error occurs when {{TcpPortProvider}} fails to find available TCP port in the local address provided by LocalAddressProvider.
> This error does not occur when I changed {{LegacyLocalAddressProvider}} (of version 0.15.0) as the default implementation of {{LocalAddressProvider}}, but it was deprecated already.
> It seems that the local address given by {{HostnameBasedLocalAddressProvider}} does not have available TCP port sometimes.
> Because of this, we need to fix it or develop another {{LocalAddressProvider}} that can provide local address with available TCP ports.
> Full message was like below.
> {quote}
> Caused by: java.lang.RuntimeException: org.apache.reef.tang.exceptions.InjectionException: Could not invoke constructor: new NettyMessagingTransport(String HostAddress = ##UNKNOWN##, Integer Port = 0, EStage RemoteClientStage = org.apache.reef.wake.remote.impl.OrderedRemoteReceiverStage@47523643, EStage RemoteServerStage = org.apache.reef.wake.remote.impl.OrderedRemoteReceiverStage@47523643, Integer NumberOfTries = 3, Integer RetryTimeout = 10000, [ClassNodeImpl 'org.apache.reef.wake.remote.ports.TcpPortProvider']: = RangeTcpPortProvider{portRangeBegin=10000, portRangeCount=10000, portRangeTryCount=1000}, LocalAddressProvider = new HostnameBasedLocalAddressProvider())
> at org.apache.reef.wake.remote.transport.netty.MessagingTransportFactory.newInstance(MessagingTransportFactory.java:135)
> at org.apache.reef.wake.remote.impl.DefaultRemoteManagerImplementation.<init>(DefaultRemoteManagerImplementation.java:89)
> at sun.reflect.NativeConstructorAccessorImpl.newInstance0(Native Method)
> at sun.reflect.NativeConstructorAccessorImpl.newInstance(NativeConstructorAccessorImpl.java:62)
> at sun.reflect.DelegatingConstructorAccessorImpl.newInstance(DelegatingConstructorAccessorImpl.java:45)
> at java.lang.reflect.Constructor.newInstance(Constructor.java:423)
> at org.apache.reef.tang.implementation.java.InjectorImpl.injectFromPlan(InjectorImpl.java:637)
> ... 50 more
> Caused by: org.apache.reef.tang.exceptions.InjectionException: Could not invoke constructor: new NettyMessagingTransport(String HostAddress = ##UNKNOWN##, Integer Port = 0, EStage RemoteClientStage = org.apache.reef.wake.remote.impl.OrderedRemoteReceiverStage@47523643, EStage RemoteServerStage = org.apache.reef.wake.remote.impl.OrderedRemoteReceiverStage@47523643, Integer NumberOfTries = 3, Integer RetryTimeout = 10000, [ClassNodeImpl 'org.apache.reef.wake.remote.ports.TcpPortProvider']: = RangeTcpPortProvider{portRangeBegin=10000, portRangeCount=10000, portRangeTryCount=1000}, LocalAddressProvider = new HostnameBasedLocalAddressProvider())
> at org.apache.reef.tang.implementation.java.InjectorImpl.injectFromPlan(InjectorImpl.java:654)
> at org.apache.reef.tang.implementation.java.InjectorImpl.getInstance(InjectorImpl.java:515)
> at org.apache.reef.tang.implementation.java.InjectorImpl.getInstance(InjectorImpl.java:533)
> at org.apache.reef.wake.remote.transport.netty.MessagingTransportFactory.newInstance(MessagingTransportFactory.java:133)
> ... 56 more
> Caused by: org.apache.reef.wake.remote.transport.exception.TransportRuntimeException: tcpPortProvider failed to return free ports.
> at org.apache.reef.wake.remote.transport.netty.NettyMessagingTransport.<init>(NettyMessagingTransport.java:183)
> at sun.reflect.NativeConstructorAccessorImpl.newInstance0(Native Method)
> at sun.reflect.NativeConstructorAccessorImpl.newInstance(NativeConstructorAccessorImpl.java:62)
> at sun.reflect.DelegatingConstructorAccessorImpl.newInstance(DelegatingConstructorAccessorImpl.java:45)
> at java.lang.reflect.Constructor.newInstance(Constructor.java:423)
> at org.apache.reef.tang.implementation.java.InjectorImpl.injectFromPlan(InjectorImpl.java:637)
> ... 59 more
> Caused by: java.lang.IllegalStateException: tcpPortProvider cannot find a free port.
> at org.apache.reef.wake.remote.transport.netty.NettyMessagingTransport.<init>(NettyMessagingTransport.java:167)
> ... 64 more
> {quote}
--
This message was sent by Atlassian JIRA
(v6.4.14#64029)