]
Paul Ferraro reassigned ISPN-6940:
----------------------------------
Assignee: (was: Paul Ferraro)
Unavailable servers with Replication timeout exception
------------------------------------------------------
Key: ISPN-6940
URL:
https://issues.jboss.org/browse/ISPN-6940
Project: Infinispan
Issue Type: Bug
Affects Versions: 8.2.3.Final
Reporter: Bogdan Sikora
Priority: Critical
Attachments: clusterbench.war
Exception in log after every request
{noformat}
ERROR [org.infinispan.interceptors.InvocationContextInterceptor] (default task-1)
ISPN000136: Error executing command GetKeyValueCommand, writing keys []:
org.infinispan.util.concurrent.TimeoutException: Replication timeout for jboss-eap-7.1-1
at
org.infinispan.remoting.transport.jgroups.JGroupsTransport.checkRsp(JGroupsTransport.java:801)
at
org.infinispan.remoting.transport.jgroups.JGroupsTransport.lambda$invokeRemotelyAsync$1(JGroupsTransport.java:642)
at java.util.concurrent.CompletableFuture.uniApply(CompletableFuture.java:602)
at java.util.concurrent.CompletableFuture$UniApply.tryFire(CompletableFuture.java:577)
at java.util.concurrent.CompletableFuture.postComplete(CompletableFuture.java:474)
at java.util.concurrent.CompletableFuture.complete(CompletableFuture.java:1962)
at
org.infinispan.remoting.transport.jgroups.CommandAwareRpcDispatcher.staggeredProcessNext(CommandAwareRpcDispatcher.java:375)
at
org.infinispan.remoting.transport.jgroups.CommandAwareRpcDispatcher.lambda$processCallsStaggered$3(CommandAwareRpcDispatcher.java:357)
at java.util.concurrent.Executors$RunnableAdapter.call(Executors.java:511)
at java.util.concurrent.FutureTask.run(FutureTask.java:266)
at
java.util.concurrent.ScheduledThreadPoolExecutor$ScheduledFutureTask.access$201(ScheduledThreadPoolExecutor.java:180)
at
java.util.concurrent.ScheduledThreadPoolExecutor$ScheduledFutureTask.run(ScheduledThreadPoolExecutor.java:293)
at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1142)
at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:617)
at java.lang.Thread.run(Thread.java:745)
09:46:25,427 ERROR [io.undertow.request] (default task-1) UT005023: Exception handling
request to /clusterbench/jvmroute: org.infinispan.util.concurrent.TimeoutException:
Replication timeout for jboss-eap-7.1-1
at
org.infinispan.remoting.transport.jgroups.JGroupsTransport.checkRsp(JGroupsTransport.java:801)
at
org.infinispan.remoting.transport.jgroups.JGroupsTransport.lambda$invokeRemotelyAsync$1(JGroupsTransport.java:642)
at java.util.concurrent.CompletableFuture.uniApply(CompletableFuture.java:602)
at java.util.concurrent.CompletableFuture$UniApply.tryFire(CompletableFuture.java:577)
at java.util.concurrent.CompletableFuture.postComplete(CompletableFuture.java:474)
at java.util.concurrent.CompletableFuture.complete(CompletableFuture.java:1962)
at
org.infinispan.remoting.transport.jgroups.CommandAwareRpcDispatcher.staggeredProcessNext(CommandAwareRpcDispatcher.java:375)
at
org.infinispan.remoting.transport.jgroups.CommandAwareRpcDispatcher.lambda$processCallsStaggered$3(CommandAwareRpcDispatcher.java:357)
at java.util.concurrent.Executors$RunnableAdapter.call(Executors.java:511)
at java.util.concurrent.FutureTask.run(FutureTask.java:266)
at
java.util.concurrent.ScheduledThreadPoolExecutor$ScheduledFutureTask.access$201(ScheduledThreadPoolExecutor.java:180)
at
java.util.concurrent.ScheduledThreadPoolExecutor$ScheduledFutureTask.run(ScheduledThreadPoolExecutor.java:293)
at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1142)
at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:617)
at java.lang.Thread.run(Thread.java:745)
{noformat}
But it never disabled whole server to every request, eap generates this pretty page with
replication error exception
{noformat}
<html><head><title>ERROR</title><style>body {
font-family: "Lucida Grande", "Lucida Sans Unicode",
"Trebuchet MS", Helvetica, Arial, Verdana, sans-serif;
margin: 5px;
}
.header {
background-image: linear-gradient(bottom, rgb(153,151,153) 8%, rgb(199,199,199)
54%);
background-image: -o-linear-gradient(bottom, rgb(153,151,153) 8%, rgb(199,199,199)
54%);
background-image: -moz-linear-gradient(bottom, rgb(153,151,153) 8%, rgb(199,199,199)
54%);
background-image: -webkit-linear-gradient(bottom, rgb(153,151,153) 8%,
rgb(199,199,199) 54%);
background-image: -ms-linear-gradient(bottom, rgb(153,151,153) 8%, rgb(199,199,199)
54%);
background-image: -webkit-gradient(
linear,
left bottom,
left top,
color-stop(0.08, rgb(153,151,153)),
color-stop(0.54, rgb(199,199,199))
);
color: black;
padding: 2px;
font-weight: normal;
border: solid 1px;
font-size: 170%;
text-align: left;
vertical-align: middle;
height: 32px;
}
.error-div {
display: inline-block; width: 32px; height: 32px; background:
url('')
left center no-repeat;
}.error-text-div {
display: inline-block; vertical-align: top; height: 32px;}.label {
font-weight:bold; display: inline-block;}.value { display:
inline-block;}</style></head><body><div
class="header"><div class="error-div"></div><div
class="error-text-div">Error processing
request</div></div><div class="label">Context
Path:</div><div
class="value">/clusterbench</div><br/><div
class="label">Servlet Path:</div><div
class="value">/jvmroute</div><br/><div
class="label">Path Info:</div><div
class="value">null</div><br/><div
class="label">Query String:</div><div
class="value">null</div><br/><b>Stack
Trace</b><br/>org.infinispan.util.concurrent.TimeoutException: Replication
timeout for
jboss-eap-7.1-1<br/>org.infinispan.remoting.transport.jgroups.JGroupsTransport.checkRsp(JGroupsTransport.java:801)<br/>org.infinispan.remoting.transport.jgroups.JGroupsTransport.lambda$invokeRemotelyAsync$1(JGroupsTransport.java:642)<br/>java.util.concurrent.CompletableFuture.uniApply(CompletableFuture.java:602)<br/>java.util.concurrent.CompletableFuture$UniApply.tryFire(CompletableFuture.java:577)<br/>java.util.concurrent.CompletableFuture.postComplete(CompletableFuture.java:474)<br/>java.util.concurrent.CompletableFuture.complete(CompletableFuture.java:1962)<br/>org.infinispan.remoting.transport.jgroups.CommandAwareRpcDispatcher.staggeredProcessNext(CommandAwareRpcDispatcher.java:375)<br/>org.infinispan.remoting.transport.jgroups.CommandAwareRpcDispatcher.lambda$processCallsStaggered$3(CommandAwareRpcDispatcher.java:357)<br/>java.util.concurrent.Executors$RunnableAdapter.call(Executors.java:511)<br/>java.util.concurrent.FutureTask.run(FutureTask.java:266)<br/>java.util.concurrent.ScheduledThreadPoolExecutor$ScheduledFutureTask.access$201(ScheduledThreadPoolExecutor.java:180)<br/>java.util.concurrent.ScheduledThreadPoolExecutor$ScheduledFutureTask.run(ScheduledThreadPoolExecutor.java:293)<br/>java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1142)<br/>java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:617)<br/>java.lang.Thread.run(Thread.java:745)<br/></body></html>
{noformat}
Reproducing
# Unzip jboss-eap-7.1.0.DR2.zip
# copy recurcive (cp -R) to have 3 jboss-eap folders (jboss-eap-7.1, jboss-eap-7.1-2,
jboss-eap-7.1-3)
# open configuration file standalone-ha.xml
# add some offset to server ports (management-http, management-https, ajp,http, https) to
remove conficts
# add with names (value) what you want
{noformat}
<system-properties>
<property name="jboss.mod_cluster.jvmRoute"
value="jboss-eap-7.1-3"/>
<property name="jboss.node.name" value="jboss-eap-7.1-3"/>
</system-properties>
{noformat}
# You should probably change ip from localhost to prevent firewall to misbehave
# copy clusterbench.war ro standalone/deployments
# start servers with standalone-ha.xml
# curl {noformat} ${YOUR_SET_IP_ADDRESS}:${SERVER_PORT}/clusterbench/jvmroute {noformat}
# one of the servers should return 500, if not restart one of them
I had third server unable to response, when i turn off second one, third came to live.
After start of second one, third one stops responding again. Sometimes more then one
server stops to respond, i have got scenario where whole cluster stopped responding.