Increase the "requestReadTimeoutDuration" from 1 hour to 3. This way, each worker will handle saturation without aborting the connection, when multiple workers are waiting for the "databaseLock" in the Controller.
This commit is contained in:
parent
edbf6461d5
commit
377b98d677
|
@ -78,8 +78,7 @@ if [[ justInstall -eq 0 ]]; then
|
||||||
#gradle tasks # For debugging installation
|
#gradle tasks # For debugging installation
|
||||||
#gradle -v # For debugging installation
|
#gradle -v # For debugging installation
|
||||||
|
|
||||||
gradle clean
|
gradle clean build
|
||||||
gradle build
|
|
||||||
else
|
else
|
||||||
export PATH=/opt/gradle/gradle-${gradleVersion}/bin:$PATH # Make sure the gradle is still accessible (it usually isn't without the "export").
|
export PATH=/opt/gradle/gradle-${gradleVersion}/bin:$PATH # Make sure the gradle is still accessible (it usually isn't without the "export").
|
||||||
fi
|
fi
|
||||||
|
|
|
@ -35,7 +35,7 @@ public class AssignmentsHandler {
|
||||||
private static String requestUrl;
|
private static String requestUrl;
|
||||||
|
|
||||||
private static final Duration requestConnectTimeoutDuration = Duration.ofMinutes(1); // 1 minute.
|
private static final Duration requestConnectTimeoutDuration = Duration.ofMinutes(1); // 1 minute.
|
||||||
private static final Duration requestReadTimeoutDuration = Duration.ofMinutes(60); // 60 minutes. Time to wait for the data to get transferred over the network. Many workers may try to get assignments from the Worker, so each worker might have to wait some 10s of minutes for work.
|
private static final Duration requestReadTimeoutDuration = Duration.ofHours(3); // 3 hours. Time to wait for the data to get transferred over the network. Many workers may try to get assignments from the Worker, so each worker might have to wait some 10s of minutes for work.
|
||||||
// The controller has to retrieve the data from the database, then prepare them in memory, insert them in the "assignment"-table and, finally, return them to the worker.
|
// The controller has to retrieve the data from the database, then prepare them in memory, insert them in the "assignment"-table and, finally, return them to the worker.
|
||||||
|
|
||||||
public static final RestTemplate restTemplate = new RestTemplateBuilder().setConnectTimeout(requestConnectTimeoutDuration).setReadTimeout(requestReadTimeoutDuration).build();
|
public static final RestTemplate restTemplate = new RestTemplateBuilder().setConnectTimeout(requestConnectTimeoutDuration).setReadTimeout(requestReadTimeoutDuration).build();
|
||||||
|
@ -64,7 +64,7 @@ public class AssignmentsHandler {
|
||||||
try { // Here, the HTTP-request is executed.
|
try { // Here, the HTTP-request is executed.
|
||||||
assignmentRequest = restTemplate.getForObject(requestUrl, AssignmentsRequest.class);
|
assignmentRequest = restTemplate.getForObject(requestUrl, AssignmentsRequest.class);
|
||||||
} catch (RestClientException rce) {
|
} catch (RestClientException rce) {
|
||||||
logger.error("Could not retrieve the assignments!\n" + rce.getMessage()); // It shows the response body (after Spring v.2.5.6).
|
logger.error("Could not retrieve the assignments!\n" + rce.getMessage()); // It shows the response body (from Spring v.2.5.6 onwards).
|
||||||
hadConnectionErrorOnRequest = true;
|
hadConnectionErrorOnRequest = true;
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue