- In case a serious error happened while processing the assignments, instead of shutting down immediately, now the Worker shuts down the executor service, registers that it will shut down soon and waits for the Controller to retrieve the already downloaded full-text files.
- In case the full-texts' subdirectory could not be created, then terminate the "handleAssignment" method immediately. No posting of a faulty workerReport to the Controller should happen. - Code polishing.
This commit is contained in:
parent
4a95826f58
commit
2aedae2367
|
@ -179,7 +179,8 @@ public class AssignmentsHandler {
|
||||||
publicationsRetrieverPlugin.processAssignments(assignmentRequestCounter, assignmentsForPlugins.values());
|
publicationsRetrieverPlugin.processAssignments(assignmentRequestCounter, assignmentsForPlugins.values());
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
logger.error("Exception when processing the assignments_" + assignmentRequestCounter, e);
|
logger.error("Exception when processing the assignments_" + assignmentRequestCounter, e);
|
||||||
} // In this case, we will either have an empty WorkerReport or a half-filled one. Either way, we want to report back to the Controller.
|
return;
|
||||||
|
} // In this case, no assignments were processed.
|
||||||
|
|
||||||
PublicationsRetriever.calculateAndPrintElapsedTime(startTime, Instant.now(), "The processing of assignments_" + assignmentRequestCounter + " finished after: ");
|
PublicationsRetriever.calculateAndPrintElapsedTime(startTime, Instant.now(), "The processing of assignments_" + assignmentRequestCounter + " finished after: ");
|
||||||
|
|
||||||
|
@ -214,7 +215,7 @@ public class AssignmentsHandler {
|
||||||
}
|
}
|
||||||
|
|
||||||
if ( GeneralController.shouldShutdownWorker
|
if ( GeneralController.shouldShutdownWorker
|
||||||
|| (AssignmentsHandler.numHandledAssignmentsBatches == this.maxAssignmentsBatchesToHandleBeforeShutdown) )
|
|| (numHandledAssignmentsBatches == this.maxAssignmentsBatchesToHandleBeforeShutdown) )
|
||||||
{
|
{
|
||||||
logger.info("The worker will shutdown, after the full-texts are delivered to the Controller, as " + (GeneralController.shouldShutdownWorker
|
logger.info("The worker will shutdown, after the full-texts are delivered to the Controller, as " + (GeneralController.shouldShutdownWorker
|
||||||
? "it received a \"shutdownWorker\" request!"
|
? "it received a \"shutdownWorker\" request!"
|
||||||
|
|
|
@ -55,7 +55,7 @@ public class ScheduledTasks {
|
||||||
|
|
||||||
@Scheduled(fixedDelay = 1) // Request the next batch immediately after the last one finishes.
|
@Scheduled(fixedDelay = 1) // Request the next batch immediately after the last one finishes.
|
||||||
public void handleNewAssignments() {
|
public void handleNewAssignments() {
|
||||||
if ( AssignmentsHandler.shouldNotRequestMore ) {
|
if ( GeneralController.shouldShutdownWorker || AssignmentsHandler.shouldNotRequestMore ) {
|
||||||
// Here we will be right after the Worker has posted its last report. It is guaranteed that the Controller will not have processed it and have not requested the full-text files.
|
// Here we will be right after the Worker has posted its last report. It is guaranteed that the Controller will not have processed it and have not requested the full-text files.
|
||||||
// We do not want to shut down the controller.
|
// We do not want to shut down the controller.
|
||||||
return;
|
return;
|
||||||
|
@ -172,7 +172,7 @@ public class ScheduledTasks {
|
||||||
|
|
||||||
long currentTime = System.currentTimeMillis();
|
long currentTime = System.currentTimeMillis();
|
||||||
|
|
||||||
// Loop through the array and print only the directories
|
// Loop through the array, check the "lastModified" time and if it is too old delete the full-texts subDir and the related workerReport.
|
||||||
for ( File subDir : fulltextSubDirs ) {
|
for ( File subDir : fulltextSubDirs ) {
|
||||||
long lastModified = subDir.lastModified();
|
long lastModified = subDir.lastModified();
|
||||||
|
|
||||||
|
|
|
@ -11,6 +11,7 @@ import eu.openaire.publications_retriever.util.url.UrlUtils;
|
||||||
import eu.openaire.urls_worker.UrlsWorkerApplication;
|
import eu.openaire.urls_worker.UrlsWorkerApplication;
|
||||||
import eu.openaire.urls_worker.components.AssignmentsHandler;
|
import eu.openaire.urls_worker.components.AssignmentsHandler;
|
||||||
import eu.openaire.urls_worker.components.ConnWithController;
|
import eu.openaire.urls_worker.components.ConnWithController;
|
||||||
|
import eu.openaire.urls_worker.controllers.GeneralController;
|
||||||
import eu.openaire.urls_worker.models.Assignment;
|
import eu.openaire.urls_worker.models.Assignment;
|
||||||
import eu.openaire.urls_worker.models.Error;
|
import eu.openaire.urls_worker.models.Error;
|
||||||
import eu.openaire.urls_worker.models.Payload;
|
import eu.openaire.urls_worker.models.Payload;
|
||||||
|
@ -153,10 +154,10 @@ public class PublicationsRetrieverPlugin {
|
||||||
|
|
||||||
int numFailedTasks = LoaderAndChecker.invokeAllTasksAndWait(callableTasks);
|
int numFailedTasks = LoaderAndChecker.invokeAllTasksAndWait(callableTasks);
|
||||||
if ( numFailedTasks == -1 ) { // The unknown exception is logged inside the above method.
|
if ( numFailedTasks == -1 ) { // The unknown exception is logged inside the above method.
|
||||||
System.err.println("Invoking and/or executing the callableTasks failed with the exception (which is written in the log files)!");
|
GeneralController.shouldShutdownWorker = true;
|
||||||
connWithController.postShutdownReportToController(workerId);
|
AssignmentsHandler.shouldNotRequestMore = true;
|
||||||
UrlsWorkerApplication.gentleAppShutdown();
|
PublicationsRetriever.executor.shutdownNow(); // Close the thread-pool immediately. It will not be used again while the Worker is still running.
|
||||||
return; // Not relly needed, but have it for code-readability.
|
throw new RuntimeException("Invoking and/or executing the callableTasks failed with the exception (which is written in the log files)!");
|
||||||
}
|
}
|
||||||
|
|
||||||
if ( numFailedTasks > 0 )
|
if ( numFailedTasks > 0 )
|
||||||
|
|
|
@ -104,7 +104,7 @@ public class GeneralController {
|
||||||
String directoryPath = PublicationsRetrieverPlugin.assignmentsBasePath + "assignments_" + assignmentsCounter + "_fullTexts";
|
String directoryPath = PublicationsRetrieverPlugin.assignmentsBasePath + "assignments_" + assignmentsCounter + "_fullTexts";
|
||||||
File dir = new File(directoryPath);
|
File dir = new File(directoryPath);
|
||||||
if ( ! dir.isDirectory() ) {
|
if ( ! dir.isDirectory() ) {
|
||||||
logger.error("The \"addRReportResultToWorker\"-endpoint was called for an unknown \"assignmentsCounter\": " + assignmentsCounter);
|
logger.error("The \"addReportResultToWorker\"-endpoint was called for an unknown \"assignmentsCounter\": " + assignmentsCounter);
|
||||||
return ResponseEntity.notFound().build();
|
return ResponseEntity.notFound().build();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue