[ 
https://issues.apache.org/jira/browse/GEODE-6789?page=com.atlassian.jira.plugin.system.issuetabpanels:all-tabpanel
 ]

Dick Cavender closed GEODE-6789.
--------------------------------

> locator fails to start even though ports in membership-port-range are 
> available
> -------------------------------------------------------------------------------
>
>                 Key: GEODE-6789
>                 URL: https://issues.apache.org/jira/browse/GEODE-6789
>             Project: Geode
>          Issue Type: Bug
>          Components: core
>            Reporter: Bruce J Schuchardt
>            Assignee: Bruce J Schuchardt
>            Priority: Major
>             Fix For: 1.10.0
>
>          Time Spent: 0.5h
>  Remaining Estimate: 0h
>
> A locator with membership-port-range of 10000-20000 threw a 
> GemFireConfigException even though ports in that range were available.
> {noformat}
> org.apache.geode.GemFireConfigException: Unable to allocate a failure 
> detection port in the membership-port range
>       at 
> org.apache.geode.distributed.internal.membership.gms.fd.GMSHealthMonitor.createServerSocket(GMSHealthMonitor.java:679)
>       at 
> org.apache.geode.distributed.internal.membership.gms.fd.GMSHealthMonitor.started(GMSHealthMonitor.java:946)
>       at 
> org.apache.geode.distributed.internal.membership.gms.Services.start(Services.java:181)
>       at 
> org.apache.geode.distributed.internal.membership.gms.GMSMemberFactory.newMembershipManager(GMSMemberFactory.java:106)
>       at 
> org.apache.geode.distributed.internal.membership.MemberFactory.newMembershipManager(MemberFactory.java:90)
>       at 
> org.apache.geode.distributed.internal.ClusterDistributionManager.<init>(ClusterDistributionManager.java:1027)
>       at 
> org.apache.geode.distributed.internal.ClusterDistributionManager.<init>(ClusterDistributionManager.java:1061)
>       at 
> org.apache.geode.distributed.internal.ClusterDistributionManager.create(ClusterDistributionManager.java:554)
>       at 
> org.apache.geode.distributed.internal.InternalDistributedSystem.initialize(InternalDistributedSystem.java:763)
>       at 
> org.apache.geode.distributed.internal.InternalDistributedSystem.newInstance(InternalDistributedSystem.java:355)
>       at 
> org.apache.geode.distributed.internal.InternalDistributedSystem.newInstance(InternalDistributedSystem.java:341)
>       at 
> org.apache.geode.distributed.internal.InternalDistributedSystem.newInstance(InternalDistributedSystem.java:335)
>       at 
> org.apache.geode.distributed.DistributedSystem.connect(DistributedSystem.java:211)
>       at 
> hydra.DistributedSystemHelper.startLocatorAndDS(DistributedSystemHelper.java:382)
>       at 
> rollingupgrade.RollingUpgradeTest.HydraTask_startLocatorAndDS(RollingUpgradeTest.java:62)
>       at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
>       at 
> sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
>       at 
> sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
>       at java.lang.reflect.Method.invoke(Method.java:498)
>       at hydra.MethExecutor.execute(MethExecutor.java:173)
>       at hydra.MethExecutor.execute(MethExecutor.java:141)
>       at hydra.TestTask.execute(TestTask.java:197)
>       at hydra.RemoteTestModule$1.run(RemoteTestModule.java:213)
> Caused by: java.net.SocketException: Address already in use (Listen failed)
>       at java.net.PlainSocketImpl.socketListen(Native Method)
>       at 
> java.net.AbstractPlainSocketImpl.listen(AbstractPlainSocketImpl.java:399)
>       at java.net.ServerSocket.bind(ServerSocket.java:376)
>       at 
> org.apache.geode.internal.net.SocketCreator.createServerSocket(SocketCreator.java:748)
>       at 
> org.apache.geode.internal.net.SocketCreator.createServerSocketUsingPortRange(SocketCreator.java:828)
>       at 
> org.apache.geode.distributed.internal.membership.gms.fd.GMSHealthMonitor.createServerSocket(GMSHealthMonitor.java:675)
>       ... 22 more{noformat}
>  
> The code that checks for free ports in that range looks for a BindException.  
> If one isn't found it looks for a SocketException with the message "Invalid 
> argument: listen failed".  In this failure the text was "Address already in 
> use (Listen failed)", which causes the search for a free port to terminate.



--
This message was sent by Atlassian Jira
(v8.3.4#803005)

Reply via email to