Class JobFrontend
- All Implemented Interfaces:
JobFrontendRef,Runnable
- Version:
- 20-Jun-2012
- Author:
- Alan Kaminsky
-
Constructor Summary
ConstructorsConstructorDescriptionJobFrontend(String username, int Nn, int Np, int Nt, boolean hasFrontendComm, String mainClassName, String[] args) Construct a new job frontend object. -
Method Summary
Modifier and TypeMethodDescriptionvoidassignBackend(JobSchedulerRef theJobScheduler, String name, String host, String jvm, String classpath, String[] jvmflags, String shellCommand, int Nt) Assign a backend process to the job.voidassignJobNumber(JobSchedulerRef theJobScheduler, int jobnum, String pjhost) Assign a job number to the job.voidbackendFinished(JobBackendRef theJobBackend) Report that a backend process has finished executing the job.voidbackendReady(JobBackendRef theJobBackend, int rank, InetSocketAddress middlewareAddress, InetSocketAddress worldAddress, InetSocketAddress frontendAddress) Report that a backend process is ready to commence executing the job.voidcancelJob(JobBackendRef theJobBackend, String errmsg) Cancel the job.voidcancelJob(JobSchedulerRef theJobScheduler, String errmsg) Cancel the job.voidclose()Close communication with this Job Frontend.voidinputFileClose(JobBackendRef theJobBackend, int ffd) Close the given input file.voidinputFileOpen(JobBackendRef theJobBackend, int bfd, File file) Open the given input file for reading.voidinputFileRead(JobBackendRef theJobBackend, int ffd, int len) Read bytes from the given input file.voidinputFileSkip(JobBackendRef theJobBackend, int ffd, long len) Skip bytes from the given input file.voidoutputFileClose(JobBackendRef theJobBackend, int ffd) Close the given output file.voidoutputFileFlush(JobBackendRef theJobBackend, int ffd) Flush accumulated bytes to the given output file.voidoutputFileOpen(JobBackendRef theJobBackend, int bfd, File file, boolean append) Open the given output file for writing or appending.voidoutputFileWrite(JobBackendRef theJobBackend, int ffd, byte[] buf, int off, int len) Write the given bytes to the given output file.voidrenewLease(JobBackendRef theJobBackend) Renew the lease on the job.voidrenewLease(JobSchedulerRef theJobScheduler) Renew the lease on the job.voidreportComment(JobBackendRef theJobBackend, int rank, String comment) Report a comment for a process.voidrequestResource(JobBackendRef theJobBackend, String resourceName) Request the given resource from this job frontend's class loader.voidrun()Run this Job Frontend.
-
Constructor Details
-
JobFrontend
public JobFrontend(String username, int Nn, int Np, int Nt, boolean hasFrontendComm, String mainClassName, String[] args) throws IOException Construct a new job frontend object. The job frontend object will contact the Job Scheduler Daemon specified by the"pj.host"and"pj.port"Java system properties. See class PJProperties for further information.- Parameters:
username- User name.Nn- Number of backend nodes (>= 1).Np- Number of processes (>= 1).Nt- Number of CPUs per process (>= 0). 0 means "all CPUs."hasFrontendComm- True if the job has the frontend communicator, false if it doesn't.mainClassName- Main class name.args- Command line arguments.- Throws:
IOException- Thrown if an I/O error occurred.IOException- if any.
-
-
Method Details
-
run
public void run()Run this Job Frontend. -
assignBackend
public void assignBackend(JobSchedulerRef theJobScheduler, String name, String host, String jvm, String classpath, String[] jvmflags, String shellCommand, int Nt) throws IOException Assign a backend process to the job.Assign a backend process to the job.
- Specified by:
assignBackendin interfaceJobFrontendRef- Parameters:
theJobScheduler- Job Scheduler that is calling this method.name- Backend node name.host- Host name for SSH remote login.jvm- Full pathname of Java Virtual Machine.classpath- Java class path for PJ Library.jvmflags- Array of JVM command line flags.shellCommand- Shell command string.Nt- Number of CPUs assigned to the process.- Throws:
IOException- Thrown if an I/O error occurred.IOException- if any.
-
assignJobNumber
public void assignJobNumber(JobSchedulerRef theJobScheduler, int jobnum, String pjhost) throws IOException Assign a job number to the job. The host name for the job frontend's middleware channel group is also specified.Assign a job number to the job. The host name for the job frontend's middleware channel group is also specified.
- Specified by:
assignJobNumberin interfaceJobFrontendRef- Parameters:
theJobScheduler- Job Scheduler that is calling this method.jobnum- Job number.pjhost- Host name for middleware channel group.- Throws:
IOException- Thrown if an I/O error occurred.IOException- if any.
-
cancelJob
Cancel the job.Cancel the job.
- Specified by:
cancelJobin interfaceJobFrontendRef- Parameters:
theJobScheduler- Job Scheduler that is calling this method.errmsg- Error message string.- Throws:
IOException- Thrown if an I/O error occurred.IOException- if any.
-
renewLease
Renew the lease on the job.- Specified by:
renewLeasein interfaceJobFrontendRef- Parameters:
theJobScheduler- Job Scheduler that is calling this method.- Throws:
IOException- Thrown if an I/O error occurred.IOException- if any.
-
backendFinished
Report that a backend process has finished executing the job.Report that a backend process has finished executing the job.
- Specified by:
backendFinishedin interfaceJobFrontendRef- Parameters:
theJobBackend- Job Backend that is calling this method.- Throws:
IOException- Thrown if an I/O error occurred.IOException- if any.
-
backendReady
public void backendReady(JobBackendRef theJobBackend, int rank, InetSocketAddress middlewareAddress, InetSocketAddress worldAddress, InetSocketAddress frontendAddress) throws IOException Report that a backend process is ready to commence executing the job.Report that a backend process is ready to commence executing the job.
- Specified by:
backendReadyin interfaceJobFrontendRef- Parameters:
theJobBackend- Job Backend that is calling this method.rank- Rank of the job backend process.middlewareAddress- Host/port to which the job backend process is listening for middleware messages.worldAddress- Host/port to which the job backend process is listening for the world communicator.frontendAddress- Host/port to which the job backend process is listening for the frontend communicator, or null if the frontend communicator does not exist.- Throws:
IOException- Thrown if an I/O error occurred.IOException- if any.
-
cancelJob
Cancel the job.Cancel the job.
- Specified by:
cancelJobin interfaceJobFrontendRef- Parameters:
theJobBackend- Job Backend that is calling this method.errmsg- Error message string.- Throws:
IOException- Thrown if an I/O error occurred.IOException- if any.
-
renewLease
Renew the lease on the job.Renew the lease on the job.
- Specified by:
renewLeasein interfaceJobFrontendRef- Parameters:
theJobBackend- Job Backend that is calling this method.- Throws:
IOException- Thrown if an I/O error occurred.IOException- if any.
-
requestResource
Request the given resource from this job frontend's class loader.Request the given resource from this job frontend's class loader.
- Specified by:
requestResourcein interfaceJobFrontendRef- Parameters:
theJobBackend- Job Backend that is calling this method.resourceName- Resource name.- Throws:
IOException- Thrown if an I/O error occurred.IOException- if any.
-
outputFileOpen
public void outputFileOpen(JobBackendRef theJobBackend, int bfd, File file, boolean append) throws IOException Open the given output file for writing or appending.Open the given output file for writing or appending.
- Specified by:
outputFileOpenin interfaceJobFrontendRef- Parameters:
theJobBackend- Job Backend that is calling this method.bfd- Backend file descriptor.file- File.append- True to append, false to overwrite.- Throws:
IOException- Thrown if an I/O error occurred.IOException- if any.
-
outputFileWrite
public void outputFileWrite(JobBackendRef theJobBackend, int ffd, byte[] buf, int off, int len) throws IOException Write the given bytes to the given output file.ffd= 1 refers to the job's standard output stream;ffd= 2 refers to the job's standard error stream; other values refer to a previously opened file.Write the given bytes to the given output file.
ffd= 1 refers to the job's standard output stream;ffd= 2 refers to the job's standard error stream; other values refer to a previously opened file.- Specified by:
outputFileWritein interfaceJobFrontendRef- Parameters:
theJobBackend- Job Backend that is calling this method.ffd- Frontend file descriptor.buf- Array of bytes to write.off- Index of first byte to write.len- Number of bytes to write.- Throws:
IOException- Thrown if an I/O error occurred.IOException- if any.
-
outputFileFlush
Flush accumulated bytes to the given output file.Flush accumulated bytes to the given output file.
- Specified by:
outputFileFlushin interfaceJobFrontendRef- Parameters:
theJobBackend- Job Backend that is calling this method.ffd- Frontend file descriptor.- Throws:
IOException- Thrown if an I/O error occurred.IOException- if any.
-
outputFileClose
Close the given output file.Close the given output file.
- Specified by:
outputFileClosein interfaceJobFrontendRef- Parameters:
theJobBackend- Job Backend that is calling this method.ffd- Frontend file descriptor.- Throws:
IOException- Thrown if an I/O error occurred.IOException- if any.
-
inputFileOpen
Open the given input file for reading.Open the given input file for reading.
- Specified by:
inputFileOpenin interfaceJobFrontendRef- Parameters:
theJobBackend- Job Backend that is calling this method.bfd- Backend file descriptor.file- File.- Throws:
IOException- Thrown if an I/O error occurred.IOException- if any.
-
inputFileRead
Read bytes from the given input file.ffd= 1 refers to the job's standard input stream; other values refer to a previously opened file.Read bytes from the given input file.
ffd= 1 refers to the job's standard input stream; other values refer to a previously opened file.- Specified by:
inputFileReadin interfaceJobFrontendRef- Parameters:
theJobBackend- Job Backend that is calling this method.ffd- Frontend file descriptor.len- Number of bytes to read.- Throws:
IOException- Thrown if an I/O error occurred.IOException- if any.
-
inputFileSkip
Skip bytes from the given input file.Skip bytes from the given input file.
- Specified by:
inputFileSkipin interfaceJobFrontendRef- Parameters:
theJobBackend- Job Backend that is calling this method.ffd- Frontend file descriptor.len- Number of bytes to skip.- Throws:
IOException- Thrown if an I/O error occurred.IOException- if any.
-
inputFileClose
Close the given input file.Close the given input file.
- Specified by:
inputFileClosein interfaceJobFrontendRef- Parameters:
theJobBackend- Job Backend that is calling this method.ffd- Frontend file descriptor.- Throws:
IOException- Thrown if an I/O error occurred.IOException- if any.
-
reportComment
Report a comment for a process.Report a comment for a process.
- Specified by:
reportCommentin interfaceJobFrontendRef- Parameters:
theJobBackend- Job backend that is calling this method.rank- Process rank.comment- Comment string.- Throws:
IOException- Thrown if an I/O error occurred.IOException- if any.
-
close
public void close()Close communication with this Job Frontend.- Specified by:
closein interfaceJobFrontendRef
-