DataFlux Data Management Studio 2.7: User Guide
You can use the dmpexec command to execute profiles, data jobs, or process jobs from the command line. The executable file for this command is installed with both DataFlux Data Management Studio and DataFlux Data Management Server. The most commonly used options are listed in the following table.
Option | Purpose | Examples |
---|---|---|
-j file | Executes the job in the specified file | -j C:\Program Files\SASHome\SASDataFluxDataManagementServer\[instance_name]\var\batch_jobs\TestJob.ddf" |
-l file | Writes the log to the specified file | -l "C:\LogLocation\Log.txt" |
-c file | Reads configuration from | -c "C:\ConfigLocation\FileName.cfg" |
-i key=value | Specifies job input variables | -i "PATH_OUT=C:\TEMP\" -i "FILE_OUT=out.txt" |
-o key=value | Overrides settings in the configuration file. | -o "MACROVAR=X" or -o "BASE/LOGCONFIG_PATH=<path>" path to the dmserver etc directory containing the batch.log.xml file |
-b key=value | Specifies job options for the job being run. Typically used for the limited set of options that are described at right. Should not be used for options that can be set using the –o option. |
-b "REPOSITORY=TestingRepos" i.e., the DataFlux Data Management Studio repository in which the job should
run |
-a no value | -c file | Attempt to authenticate with the authentication server that is specified in the BASE/AUTH_SERVER_LOC option. Note that the BASE/AUTH_SERVER_LOC option points to a SAS Metadata Server. |
-a |
DataFlux jobs are stored in repositories. When you work with jobs interactively in DataFlux Data Management Studio, the parent repository for a selected job is always known to the application. However, when you execute jobs in batch mode, the parent repository for job is not known to the batch command. Accordingly, in most case you will specify the parent repository in the batch command that is used to execute a job.
You must specify the repository if the job uses one of the following:
The repository to use is specified with the BASE/REPOS_FILE_ROOT configuration option. It points the directory that you normally specify as the File Storage folder when you define the repository in DataFlux Data Management Studio. Here is an example of how to execute a job that does not have dependencies on a specific repository:
"C:\Program Files\SASHome\SASDataFluxDataManagementStudio\bin\dmpexec\[instance_name]\bin\dmpexec"
-j "C:\ProgramData\DataFlux\DMStudio\[instance_name]\Repository\Sample\FileStorage\batch_jobs\my_data_job.ddf"
-l "C:\TEMP\my_data_job.log"
If the job has dependencies on other items stored in the repository, the invocation would be as follows:
"C:\Program Files (x86)\DataFlux\DMStudio\[instance_name]\bin\dmpexec"
-j "C:\ProgramData\DataFlux\DMStudio\[instance_name]\Repository\Sample\FileStorage\batch_jobs\my_data_job.ddf"
-l "C:\TEMP\my_data_job.log"
-o "BASE/REPOS_FILE_ROOT= C:\ProgramData\DataFlux\DMStudio\[instance_name]\Repository\Sample\FileStorage"
Jobs with Domain-Enabled Data Connections. If the job uses data connections, and the data connections specify domains (you are using Domain-Enabled connections), you will need to specify options so dmpexec knows where to find the authentication provider to use for authentication. The data connection will then request outbound logins from the authentication provider. You can specify the authentication credentials on the command line directly, or you can store them in a separate text file and use the -c option on the command line to point to it. The following example stores the credentials in a separate file called C:\my_auth_credentials.txt that contains the following statements:
BASE/AUTH_SERVER_USER = <userid>
BASE/AUTH_SERVER_PASS = <password>
BASE/AUTH_SERVER_USER and BASE/AUTH_SERVER_PASS specify the user name and password to present when connecting to the authenticating server that is specified by the BASE/AUTH_SERVER_LOC option. Typically, BASE/AUTH_SERVER_LOC will be specified at installation time in the app.cfg file. Note that the BASE/AUTH_SERVER_LOC option points to a SAS Metadata Server. Here is an example of how to run the job using these credentials.
"C:\Program Files (x86)\DataFlux\DMStudio\[instance_name]\bin\dmpexec"
-j "C:\ProgramData\DataFlux\DMStudio\[instance_name]\Repository\Sample\FileStorage\batch_jobs\my_data_job.ddf"
-l "C:\TEMP\my_data_job.log"
-o "BASE/REPOS_FILE_ROOT= C:\ProgramData\DataFlux\DMStudio\[instance_name]\Repository\Sample\FileStorage"
-c "C:\my_auth_credentials.txt"
By default, the dmpexec command for DataFlux Data Management Server is installed in the Program Files\SASHome\SASDataFluxDataManagementServer\bin
folder on the server machine. Using this command, you execute jobs using the DataFlux Data Management Server. Note that the dmpexec command does not communicate with a running DataFlux Data Management Server. It starts its own process using the software that has been installed for DataFlux Data Management Server. If you want to execute jobs on a running server, you should use the SOAP interface, which is described in the DataFlux Data Management Server: Administrator's Guide.
When using dmpexec on a DataFlux Data Management Server, keep in mind that the dmserver.cfg file will not be used by default. If your job requires any of the configuration options that are specified in this file, you will need to make the needed options available to dmpexec. This can be done by adding the following option to your dmpexec invocation:
-c "<full-path-to-file>\dmserver.cfg"
When using dmpexec, you must specify the location of the repository if the job uses one of the following:
The repository to use is specified with the BASE/REPOS_FILE_ROOT configuration option. In a default installation, this should point to the DataFlux Data Management Server var directory. Here is a sample invocation:
"C:\Program Files\SASHome\DataFluxDataManagementServer\[instance_name]\bin\dmpexec"
-j "C:\Program Files\SASHome\DataFluxDataManagementServer\[instance_name]\var\batch_jobs\my_data_job.ddf"
-l "C:\TEMP\my_data_job.log"
-o "BASE/REPOS_FILE_ROOT=C:\Program Files\SASHome\DataFluxDataManagementServer\[instance_name]\var"
BASE/REPOS_FILE_ROOT configuration option. When dmpexec runs a job on a DataFlux Data Management Server that references other jobs using relative paths, such as "dfr//…", you must set the BASE/REPOS_FILE_ROOT configuration option and point it to the var directory. In a default deployment this you would specify it as follows:
BASE/REPOS_FILE_ROOT = C:\Program Files\DataFlux\DMServer\[instance_name]\var
Secured DataFlux Data Management Server. When using dmpexec to run jobs on a secured DataFlux Data Management Server , you must use the -a option. The command will not honor the DMSERVER/SECURE=YES configuration option.
The following options enable you to specify authentication credentials.
BASE/AUTH_SERVER_USER = <userid>
BASE/AUTH_SERVER_PASS = <password>
BASE/AUTH_SERVER_USER and BASE/AUTH_SERVER_PASS specify the user name and password to present when connecting to the authenticating server that is specified by the BASE/AUTH_SERVER_LOC option. Typically, BASE/AUTH_SERVER_LOC will be specified at installation time in the app.cfg file. Note that the BASE/AUTH_SERVER_LOC option points to a SAS Metadata Server.
The BASE/AUTH_SERVER_USER and BASE/AUTH_SERVER_PASS options can be specified in a configuration file and then used as part of a dmpexec command using the -c option, as shown in previous sections. It is also possible to specify them directly on the dmpexec command by using the -b option.
Jobs with Domain-Enabled Data Connections. If the job uses data connections, and the data connections specify domains (you are using Domain-Enabled connections), you will need to specify options so dmpexec knows where to find the authentication provider to use for authentication. The data connection will then request outbound logins from the authentication provider. You can specify the authentication credentials on the command line directly, or you can store them in a separate text file and use the -c option on the command line to point to it. The following example stores the credentials in a separate file called C:\my_auth_credentials.txt that contains the following statements:
BASE/AUTH_SERVER_USER = <userid>
BASE/AUTH_SERVER_PASS = <password>
BASE/AUTH_SERVER_USER and BASE/AUTH_SERVER_PASS specify the user name and password to present when connecting to the authenticating server that is specified by the BASE/AUTH_SERVER_LOC option. Typically, BASE/AUTH_SERVER_LOC will be specified at installation time in the app.cfg file. Note that the BASE/AUTH_SERVER_LOC option points to a SAS Metadata Server.
Here is an example to run the job using these credentials.
"C:\Program Files\SASHome\DataFluxDataManagementServer\[instance_name]\bin\dmpexec"
-j " C:\Program Files\SASHome\DataFluxDataManagementServer\[instance_name]\var\batch_jobs\my_data_job.ddf"
-l "C:\TEMP\my_data_job.log"
-o "BASE/REPOS_FILE_ROOT= C:\Program Files\SASHome\DataFluxDataManagementServer\[instance_name\var"
-a
-c "C:\my_auth_credentials.txt"
If you use a dmpexec command to execute a job that references other jobs, profiles, rules, tasks, custom metrics, sources, or fields in a DataFlux repository, then both the job and these objects must reside in the same repository.
SAS® Job Monitor is an optional component in SAS® Environment Manager. It reads job logs at specified locations and displays run-time statistics from the logs. You can use a dmpexec command to execute a job that will display statistics in SAS Job Monitor. The following special considerations apply when you use a dmpexec command to run a job whose run-time statistics will be displayed in SAS Job Monitor.
You can use the -i, -b and -o options multiple times to set multiple values.
If you will be submitting jobs through the command line on a regular basis, you might want to document the physical paths to data jobs and process jobs that you work with. The interface displays the paths to these jobs, but only in an abbreviated form. You can perform the following steps to identify the paths to data jobs and process jobs:
Note that process jobs that contain referenced jobs in their flows can sometimes fail to execute in batch mode. You can use the -o option to explicitly specify the repository for referenced jobs. Then you can execute these jobs in batch mode.
A typical approach to running jobs from the command line is to create a .cmd file and add one or more dmpexec commands to that file. For example, you could create a file called runjob.cmd that contains the following syntax:
call dmpexec _command1
call dmpexec _command2
etc.
To run the commands in the runjob.cmd file, you would enter runjob at the command line. For example, the file to run a data job named dfsample_concatenate.ddf and create a log file would contain the following command:
call dmpexec -l "mylog.txt" -j "Fully_Qualified_Path\dfsample_concatenate.ddf"
By default, the fully-qualified path to dmpexec is similar to drive:\Program Files\DataFlux\DMStudio \[instance_name]\bin. Information about finding the fully-qualified path to your jobs is available in Identify Paths to Jobs.
Running a process job is similar. You can run a process job called dmsample_echo.djf and create a log file with a .cmd file that contains the following command:
call dmpexec -l "mylog.txt" -j "Fully_Qualified_Path\dmsample_echo.djf"
The command used to run a profile is somewhat different than the command for data jobs and process jobs. An intermediate process job (ProfileExec.djf) is used to run the profile, and the profile is specified by its Batch Run ID.
Profiles are not stored as files. Instead, they are stored as metadata. Accordingly, to run a profile from the command line, you must specify a Batch Run ID for the profile instead of a file path. To find this Batch Run ID, navigate to the Folder riser and select the profile that you need to run. The Batch Run ID is displayed in the Details section of the information pane for the profile.
Here is an example command that could be used in a .cmd file:
call dmpexec -j "install dir\DMStudio\[instance_name]\etc\repositories\ProfileExec.djf" -i "REPOS_NAME=Repository_Name" -i "JOB_ID=Batch Run ID"
You can review the return code from a job that you run from the command line. This code can be useful when you need to troubleshoot a failed job. The return codes are listed in the following table.
Return Code | Description |
---|---|
0 | Success |
1 | Job initialization failure |
2 | Job was canceled |
3 | Job failed during execution |
Documentation Feedback: yourturn@sas.com
|
Doc ID: dfU_T_DataJob_RunBatch.html |