public class T2 extends AbstractMultipleFTPerXFERJob
The T2 client is generally invoked on the remote execution sites, unless the
user uses the thirdparty transfer option, in which case the T2 is invoked on
the submit host. Hence there should be an entry in the transformation catalog
for logical transformation T2
at the execution sites.
T2 is distributed as part of the Pegasus worker package and can be found at
$PEGASUS_HOME/bin/T2.
It leads to the creation of the setup chmod jobs to the workflow, that appear as parents to compute jobs in case the transfer implementation does not preserve the X bit on the file being transferred. This is required for staging of executables as part of the workflow. The setup jobs are only added as children to the stage in jobs.
In order to use the transfer implementation implemented by this class,
- the property pegasus.transfer.*.impl must be set to value T2.
There should be an entry in the transformation catalog with the fully qualified
name as pegasus::T2
for all the sites where workflow is run,
or on the local site in case of third party transfers.
The arguments with which the client is invoked can be specified
- by specifying the property pegasus.transfer.arguments - associating the Pegasus profile key transfer.arguments
Modifier and Type | Field and Description |
---|---|
static String |
DERIVATION_NAME
The name of the underlying derivation.
|
static String |
DERIVATION_NAMESPACE
The derivation namespace for for the transfer job.
|
static String |
DERIVATION_VERSION
The derivation version number for the transfer job.
|
static String |
DESCRIPTION
A short description of the transfer implementation.
|
protected String |
mNumOfTXProcesses
The number of g-u-c processes that are spawned to transfer the files in
one transfer job.
|
protected String |
mNumOfTXStreams
The number of streams that each g-u-c process opens to do the ftp transfer.
|
protected boolean |
mUseForce
Whether to use force option for the transfer executable or not.
|
static String |
TRANSFORMATION_NAME
The name of the underlying transformation that is queried for in the
Transformation Catalog.
|
static String |
TRANSFORMATION_NAMESPACE
The transformation namespace for the transfer job.
|
static String |
TRANSFORMATION_VERSION
The version number for the transfer job.
|
CHANGE_XBIT_TRANSFORMATION, mAddNodesForSettingXBit, mChmodDisabledForAllSites, mDisabledChmodSites, mLocalIrodsEnv, mLocalIrodsEnvBasename, mLocalS3cfg, mLocalS3cfgBasename, mLocalUserProxy, mLocalUserProxyBasename, mLogger, mPOptions, mProps, mRefiner, mSiteStore, mTCHandle, NOOP_PREFIX, SET_XBIT_PREFIX, XBIT_DERIVATION_NS, XBIT_DERIVATION_VERSION, XBIT_EXECUTABLE_BASENAME, XBIT_TRANSFORMATION_NS, XBIT_TRANSFORMATION_VERSION
TRANSFER_UNIVERSE, VERSION
Constructor and Description |
---|
T2(PegasusBag bag)
The overloaded constructor, that is called by the Factory to load the
class.
|
Modifier and Type | Method and Description |
---|---|
boolean |
doesPreserveXBit()
Returns a boolean indicating whether the transfer protocol being used by
the implementation preserves the X Bit or not while staging.
|
protected String |
generateArgumentString(TransferJob job)
It constructs the arguments to the transfer executable that need to be passed
to the executable referred to in this transfer mode.
|
protected String |
getCompleteTCName()
Returns the complete name for the transformation.
|
protected String |
getDerivationName()
Returns the logical name of the derivation that this implementation
refers to.
|
protected String |
getDerivationNamespace()
Returns the namespace of the derivation that this implementation
refers to.
|
protected String |
getDerivationVersion()
Returns the version of the derivation that this implementation
refers to.
|
String |
getDescription()
Returns a textual description of the transfer implementation.
|
protected List |
getEnvironmentVariables(String site)
Returns the environment profiles that are required for the default
entry to sensibly work.
|
TransformationCatalogEntry |
getTransformationCatalogEntry(String siteHandle,
int jobClass)
Retrieves the transformation catalog entry for the executable that is
being used to transfer the files in the implementation.
|
boolean |
useThirdPartyTransferAlways()
Return a boolean indicating whether the transfers to be done always in
a third party transfer mode.
|
protected void |
writeStdInAndAssociateCredentials(TransferJob job,
FileWriter writer,
Collection files,
String stagingSite,
int jobClass)
Writes to a FileWriter stream the stdin which T2 takes via standard input.
|
createTransferJob, defaultTCEntry, postProcess, prepareSTDINAndAssociateCredentials
addSetXBitJobs, addSetXBitJobs, addSetXBitJobs, applyPriority, checkAndTransferIrodsEnvFile, checkAndTransferProxy, construct, createNoOPJob, createSetXBitJob, createSetXBitJob, createSetXBitJob, determineDisabledChmodSites, disableChmodJobCreation, getNOOPJobName, getPriority, getSetXBitJobName, setRefiner
public static final String TRANSFORMATION_NAMESPACE
public static final String TRANSFORMATION_NAME
public static final String TRANSFORMATION_VERSION
public static final String DERIVATION_NAMESPACE
public static final String DERIVATION_NAME
public static final String DERIVATION_VERSION
public static final String DESCRIPTION
protected String mNumOfTXProcesses
protected String mNumOfTXStreams
protected boolean mUseForce
public T2(PegasusBag bag)
bag
- the bag of initialization objects.public boolean useThirdPartyTransferAlways()
A value of false does not preclude third party transfers. They still can be done, by setting the property "pegasus.transfer.*.thirdparty.sites".
PegasusProperties.getThirdPartySites(String)
public boolean doesPreserveXBit()
public String getDescription()
public TransformationCatalogEntry getTransformationCatalogEntry(String siteHandle, int jobClass)
siteHandle
- the handle of the site where the transformation is
to be searched.jobClass
- the job Class for the newly added job. Can be one of the
following:
stage-in
stage-out
inter-pool transfer
stage-in worker transferprotected String getDerivationNamespace()
getDerivationNamespace
in class AbstractMultipleFTPerXFERJob
protected String getDerivationName()
getDerivationName
in class AbstractMultipleFTPerXFERJob
protected String getDerivationVersion()
getDerivationVersion
in class AbstractMultipleFTPerXFERJob
protected String generateArgumentString(TransferJob job)
generateArgumentString
in class AbstractMultipleFTPerXFERJob
job
- the object containing the transfer node.protected void writeStdInAndAssociateCredentials(TransferJob job, FileWriter writer, Collection files, String stagingSite, int jobClass) throws Exception
writeStdInAndAssociateCredentials
in class AbstractMultipleFTPerXFERJob
job
- the transfer job.writer
- the writer to the stdin file.files
- Collection of FileTransfer
objects containing
the information about sourceam fin and destURL's.stagingSite
- the site where the data will be populated by first
level staging jobs.jobClass
- the job Class for the newly added job. Can be one of the
following:
stage-in
stage-out
inter-pool transferException
org.griphyn.cPlanner.classes.FileTransfer#toString()
protected String getCompleteTCName()
getCompleteTCName
in class AbstractMultipleFTPerXFERJob
protected List getEnvironmentVariables(String site)
getEnvironmentVariables
in class AbstractMultipleFTPerXFERJob
site
- the site where the job is going to run.Copyright © 2011 The University of Southern California. All Rights Reserved.