Note
Access to this page requires authorization. You can try signing in or changing directories.
Access to this page requires authorization. You can try changing directories.
In Azure Batch, each task has a working directory under which it can create files and directories. This working directory can be used for storing the program that is run by the task, the data that it processes, and the output of the processing it performs. All files and directories of a task are owned by the task user.
The Batch service exposes a portion of the file system on a node as the root directory. This root directory is located on the temporary storage drive of the VM, not directly on the OS drive.
Tasks can access the root directory by referencing the AZ_BATCH_NODE_ROOT_DIR environment variable. For more information about using environment variables, see Environment settings for tasks.
Root directory structure
The root directory contains the following directory structure:

- applications: Contains information about the details of application packages installed on the compute node. Tasks can access this directory by referencing the - AZ_BATCH_APP_PACKAGEenvironment variable.
- fsmounts: The directory contains any file systems that are mounted on a compute node. Tasks can access this directory by referencing the - AZ_BATCH_NODE_MOUNTS_DIRenvironment variable. For more information, see Mount a virtual file system on a Batch pool.
- shared: This directory provides read/write access to all tasks that run on a node. Any task that runs on the node can create, read, update, and delete files in this directory. Tasks can access this directory by referencing the - AZ_BATCH_NODE_SHARED_DIRenvironment variable.
- startup: This directory is used by a start task as its working directory. All of the files that are downloaded to the node by the start task are stored here. The start task can create, read, update, and delete files under this directory. Tasks can access this directory by referencing the - AZ_BATCH_NODE_STARTUP_DIRenvironment variable.
- volatile: This directory is for internal purposes. There's no guarantee that any files in this directory or that the directory itself will exist in the future. 
- workitems: This directory contains the directories for jobs and their tasks on the compute node. - Within the workitems directory, a Tasks directory is created for each task that runs on the node. This directory can be accessed by referencing the - AZ_BATCH_TASK_DIRenvironment variable.- Within each Tasks directory, the Batch service creates a working directory ( - wd) whose unique path is specified by the- AZ_BATCH_TASK_WORKING_DIRenvironment variable. This directory provides read/write access to the task. The task can create, read, update, and delete files under this directory. This directory is retained based on the RetentionTime constraint that is specified for the task.- The - stdout.txtand- stderr.txtfiles are written to the Tasks folder during the execution of the task.
Important
When a node is removed from the pool, all of the files that are stored on the node are removed.
Batch root directory location
The value of the AZ_BATCH_NODE_ROOT_DIR compute node environment variable will be determined by the VM size and the presence of a local temporary disk.
| Local Temporary Disk Present | Operating System Type | AZ_BATCH_NODE_ROOT_DIRValue | 
|---|---|---|
| No | Linux | /opt/batch/data | 
| Yes | Linux | /mnt/batchor/mnt/resource/batch | 
| No | Windows | C:\batch\data | 
| Yes | Windows | D:\batch | 
These environment variable values are implementation details and should not be considered immutable. As these values may change at any time, the use of environment variables instead of hardcoding the value is recommended.
Next steps
- Learn about error handling and detection in Azure Batch.