FTS3Job
FTS3Job module containing only the FTS3Job class
- class DIRAC.DataManagementSystem.Client.FTS3Job.FTS3Job
Bases:
JSerializable
Abstract class to represent a job to be executed by FTS. It belongs to an FTS3Operation
- ALL_STATES = ['Submitted', 'Ready', 'Active', 'Finished', 'Canceled', 'Failed', 'Finisheddirty', 'Staging', 'Archiving']
- FINAL_STATES = ['Canceled', 'Failed', 'Finished', 'Finisheddirty']
- INIT_STATE = 'Submitted'
- NON_FINAL_STATES = ['Staging', 'Submitted', 'Active', 'Ready', 'Archiving']
- __init__()
- assignment
- cancel(context)
Cancel the job on the FTS server. Note that it will cancel all the files. See https://fts3-docs.web.cern.ch/fts3-docs/fts-rest/docs/api.html#delete-jobsjobidlist for behavior details
- completeness
- error
- ftsGUID
- ftsServer
- static generateContext(ftsServer, ucert, lifetime=25200)
This method generates an fts3 context
- Parameters:
ftsServer – address of the fts3 server
ucert – the path to the certificate to be used
lifetime – duration (in sec) of the delegation to the FTS3 server (default is 7h, like FTS3 default)
- Returns:
an fts3 context
- jobID
- lastMonitor
- lastUpdate
- monitor(context=None, ftsServer=None, ucert=None)
Queries the fts server to monitor the job. The internal state of the object is updated depending on the monitoring result.
In case the job is not found on the server, the status is set to ‘Failed’
Within a job, only the transfers having a fileID metadata are considered. This is to allow for multihop jobs doing a staging
This method assumes that the attribute self.ftsGUID is set
- Parameters:
context – fts3 context. If not given, it is created (see ftsServer & ucert param)
ftsServer – the address of the fts server to submit to. Used only if context is not given. if not given either, use the ftsServer object attribute
ucert – path to the user certificate/proxy. Might be infered by the fts cli (see its doc)
- Returns:
{FileID: { status, error } }
Possible error numbers
errno.ESRCH: If the job does not exist on the server
errno.EDEADLK: In case the job and file status are inconsistent (see comments inside the code)
- operationID
- status
- submit(context=None, ftsServer=None, ucert=None, pinTime=36000, protocols=None)
submit the job to the FTS server
- Some attributes are expected to be defined for the submission to work:
type (set by FTS3Operation)
sourceSE (only for Transfer jobs)
targetSE
activity (optional)
priority (optional)
username
userGroup
filesToSubmit
operationID (optional, used as metadata for the job)
We also expect the FTSFiles have an ID defined, as it is given as transfer metadata
- Parameters:
pinTime – Time the file should be pinned on disk (used for transfers and staging) Used only if he source SE is a tape storage
context – fts3 context. If not given, it is created (see ftsServer & ucert param)
ftsServer – the address of the fts server to submit to. Used only if context is not given. if not given either, use the ftsServer object attribute
ucert – path to the user certificate/proxy. Might be inferred by the fts cli (see its doc)
protocols – list of protocols from which we should choose the protocol to use
- Returns:
S_OK([FTSFiles ids of files submitted])
- submitTime
- userGroup
- username