Skip to content

Commit

Permalink
116609: Improve running process observability
Browse files Browse the repository at this point in the history
- keep temp process log files in [dspace]/log/processes/ instead of temp dir
- reformat file names of process logs
- ensure that running and scheduled processes are cleaned up during startup
  • Loading branch information
nona-luypaert committed Jul 24, 2024
1 parent 5a43e6b commit d80f49e
Show file tree
Hide file tree
Showing 2 changed files with 49 additions and 15 deletions.
56 changes: 45 additions & 11 deletions dspace-api/src/main/java/org/dspace/scripts/ProcessServiceImpl.java
Original file line number Diff line number Diff line change
Expand Up @@ -45,14 +45,15 @@
import org.dspace.core.LogHelper;
import org.dspace.eperson.EPerson;
import org.dspace.eperson.Group;
import org.dspace.eperson.service.EPersonService;
import org.dspace.scripts.service.ProcessService;
import org.dspace.services.ConfigurationService;
import org.springframework.beans.factory.InitializingBean;
import org.springframework.beans.factory.annotation.Autowired;

/**
* The implementation for the {@link ProcessService} class
*/
public class ProcessServiceImpl implements ProcessService {
public class ProcessServiceImpl implements ProcessService, InitializingBean {

private static final Logger log = org.apache.logging.log4j.LogManager.getLogger(ProcessService.class);

Expand All @@ -72,7 +73,26 @@ public class ProcessServiceImpl implements ProcessService {
private MetadataFieldService metadataFieldService;

@Autowired
private EPersonService ePersonService;
private ConfigurationService configurationService;

@Override
public void afterPropertiesSet() throws Exception {
Context context = new Context();

// Processes that were running or scheduled when tomcat crashed, should be cleaned up during startup.
List<Process> processesToBeFailed = findByStatusAndCreationTimeOlderThan(
context, List.of(ProcessStatus.RUNNING, ProcessStatus.SCHEDULED), new Date());
for (Process process : processesToBeFailed) {
context.setCurrentUser(process.getEPerson());
// Fail the process.
log.info("Process with ID {} did not complete before tomcat shutdown, failing it now.", process.getID());
fail(context, process);
// But still attach its log to the process.
createLogBitstream(context, process);
}

context.complete();
}

@Override
public Process create(Context context, EPerson ePerson, String scriptName,
Expand Down Expand Up @@ -286,8 +306,8 @@ public int countSearch(Context context, ProcessQueryParameterContainer processQu
@Override
public void appendLog(int processId, String scriptName, String output, ProcessLogLevel processLogLevel)
throws IOException {
File tmpDir = FileUtils.getTempDirectory();
File tempFile = new File(tmpDir, scriptName + processId + ".log");
File logsDir = getLogsDirectory();
File tempFile = new File(logsDir, processId + "-" + scriptName + ".log");
FileWriter out = new FileWriter(tempFile, true);
try {
try (BufferedWriter writer = new BufferedWriter(out)) {
Expand All @@ -302,12 +322,15 @@ public void appendLog(int processId, String scriptName, String output, ProcessLo
@Override
public void createLogBitstream(Context context, Process process)
throws IOException, SQLException, AuthorizeException {
File tmpDir = FileUtils.getTempDirectory();
File tempFile = new File(tmpDir, process.getName() + process.getID() + ".log");
FileInputStream inputStream = FileUtils.openInputStream(tempFile);
appendFile(context, process, inputStream, Process.OUTPUT_TYPE, process.getName() + process.getID() + ".log");
inputStream.close();
tempFile.delete();
File logsDir = getLogsDirectory();
File tempFile = new File(logsDir, process.getID() + "-" + process.getName() + ".log");
if (tempFile.exists()) {
FileInputStream inputStream = FileUtils.openInputStream(tempFile);
appendFile(context, process, inputStream, Process.OUTPUT_TYPE,
process.getID() + "-" + process.getName() + ".log");
inputStream.close();
tempFile.delete();
}
}

@Override
Expand Down Expand Up @@ -336,4 +359,15 @@ private String formatLogLine(int processId, String scriptName, String output, Pr
return sb.toString();
}

private File getLogsDirectory() {
String pathStr = configurationService.getProperty("dspace.dir")
+ File.separator + "log" + File.separator + "processes";
File logsDir = new File(pathStr);
if (!logsDir.exists()) {
if (!logsDir.mkdirs()) {
throw new RuntimeException("Couldn't create [dspace.dir]/log/processes/ directory.");
}
}
return logsDir;
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -856,10 +856,10 @@ public void getProcessOutput() throws Exception {
getClient(token).perform(get("/api/system/processes/" + process1.getID() + "/output"))
.andExpect(status().isOk())
.andExpect(jsonPath("$.name",
is(process1.getName() + process1.getID() + ".log")))
is(process1.getID() + "-" + process1.getName() + ".log")))
.andExpect(jsonPath("$.type", is("bitstream")))
.andExpect(jsonPath("$.metadata['dc.title'][0].value",
is(process1.getName() + process1.getID() + ".log")))
is(process1.getID() + "-" + process1.getName() + ".log")))
.andExpect(jsonPath("$.metadata['dspace.process.filetype'][0].value",
is("script_output")));

Expand All @@ -869,10 +869,10 @@ public void getProcessOutput() throws Exception {
.perform(get("/api/system/processes/" + process1.getID() + "/output"))
.andExpect(status().isOk())
.andExpect(jsonPath("$.name",
is(process1.getName() + process1.getID() + ".log")))
is(process1.getID() + "-" + process1.getName() + ".log")))
.andExpect(jsonPath("$.type", is("bitstream")))
.andExpect(jsonPath("$.metadata['dc.title'][0].value",
is(process1.getName() + process1.getID() + ".log")))
is(process1.getID() + "-" + process1.getName() + ".log")))
.andExpect(jsonPath("$.metadata['dspace.process.filetype'][0].value",
is("script_output")));

Expand Down

0 comments on commit d80f49e

Please sign in to comment.