@InterfaceAudience.Public @InterfaceStability.Stable public class NativeAzureFileSystem extends FileSystem
FileSystem for reading and writing files stored on Windows Azure. This implementation is
 blob-based and stores files on Azure in their native form so they can be read
 by other Azure tools.| Modifier and Type | Field and Description | 
|---|---|
| static String | APPEND_SUPPORT_ENABLE_PROPERTY_NAME | 
| static String | AZURE_CHMOD_USERLIST_PROPERTY_NAMEConfiguration property used to specify list of users that can perform
 chmod operation when authorization is enabled in WASB. | 
| static String | AZURE_CHOWN_USERLIST_PROPERTY_NAMEConfiguration property used to specify list of users that can perform
 chown operation when authorization is enabled in WASB. | 
| static String | AZURE_DAEMON_USERLIST_PROPERTY_NAMEConfiguration property used to specify list of daemon users that can
 perform chmod operation when authorization is enabled in WASB. | 
| static String | AZURE_DELETE_THREADSThe configuration property to set number of threads to be used for delete operation. | 
| static String | AZURE_RENAME_THREADSThe configuration property to set number of threads to be used for rename operation. | 
| static int | DEFAULT_AZURE_DELETE_THREADSThe default number of threads to be used for delete operation. | 
| static int | DEFAULT_AZURE_RENAME_THREADSThe default number of threads to be used for rename operation. | 
| static String | KEY_AZURE_AUTHORIZATIONConfiguration key to enable authorization support in WASB. | 
| static org.slf4j.Logger | LOG | 
| static String | RETURN_URI_AS_CANONICAL_SERVICE_NAME_PROPERTY_NAME | 
| static String | SKIP_AZURE_METRICS_PROPERTY_NAME | 
DEFAULT_FS, FS_DEFAULT_NAME_KEY, SHUTDOWN_HOOK_PRIORITY, statistics, TRASH_PREFIX, USER_HOME_PREFIX| Constructor and Description | 
|---|
| NativeAzureFileSystem() | 
| NativeAzureFileSystem(org.apache.hadoop.fs.azure.NativeFileSystemStore store) | 
| Modifier and Type | Method and Description | 
|---|---|
| void | access(Path path,
      FsAction mode)Checks if the user can access a path. | 
| org.apache.hadoop.fs.azure.SelfRenewingLease | acquireLease(Path path)Get a self-renewing lease on the specified file. | 
| FSDataOutputStream | append(Path f,
      int bufferSize,
      Progressable progress)This optional operation is not yet supported. | 
| protected void | checkPath(Path path)Check that a Path belongs to this FileSystem. | 
| void | close()Close this FileSystem instance. | 
| FSDataOutputStream | create(Path f,
      FsPermission permission,
      boolean overwrite,
      int bufferSize,
      short replication,
      long blockSize,
      Progressable progress)Create an FSDataOutputStream at the indicated Path with write-progress
 reporting. | 
| protected FSDataOutputStream | createInternal(Path f,
              FsPermission permission,
              boolean overwrite,
              org.apache.hadoop.fs.azure.SelfRenewingLease parentFolderLease)This is the version of the create call that is meant for internal usage. | 
| FSDataOutputStream | createNonRecursive(Path f,
                  boolean overwrite,
                  int bufferSize,
                  short replication,
                  long blockSize,
                  Progressable progress)Opens an FSDataOutputStream at the indicated Path with write-progress
 reporting. | 
| FSDataOutputStream | createNonRecursive(Path f,
                  FsPermission permission,
                  boolean overwrite,
                  int bufferSize,
                  short replication,
                  long blockSize,
                  Progressable progress)Opens an FSDataOutputStream at the indicated Path with write-progress
 reporting. | 
| FSDataOutputStream | createNonRecursive(Path f,
                  FsPermission permission,
                  EnumSet<CreateFlag> flags,
                  int bufferSize,
                  short replication,
                  long blockSize,
                  Progressable progress)Opens an FSDataOutputStream at the indicated Path with write-progress
 reporting. | 
| boolean | delete(Path path)Deprecated.  | 
| boolean | delete(Path f,
      boolean recursive)Delete a file. | 
| boolean | delete(Path f,
      boolean recursive,
      boolean skipParentFolderLastModifiedTimeUpdate)Delete the specified file or folder. | 
| void | deleteFilesWithDanglingTempData(Path root)Looks under the given root path for any blob that are left "dangling",
 meaning that they are place-holder blobs that we created while we upload
 the data to a temporary blob, but for some reason we crashed in the middle
 of the upload and left them there. | 
| protected boolean | existsInternal(Path f)Checks if a given path exists in the filesystem. | 
| protected void | finalize() | 
| String | getCanonicalServiceName()If fs.azure.override.canonical.service.name is set as true, return URI of
 the WASB filesystem, otherwise use the default implementation. | 
| Token<?> | getDelegationToken(String renewer)Get a delegation token from remote service endpoint if
 'fs.azure.enable.kerberos.support' is set to 'true'. | 
| FileStatus | getFileStatus(Path f)Return a file status object that represents the path. | 
| Path | getHomeDirectory()Return the current user's home directory in this FileSystem. | 
| AzureFileSystemInstrumentation | getInstrumentation()Gets the metrics source for this file system. | 
| String | getOwnerForPath(Path absolutePath) | 
| String | getScheme()Return the protocol scheme for this FileSystem. | 
| org.apache.hadoop.fs.azure.AzureNativeFileSystemStore | getStore()For unit test purposes, retrieves the AzureNativeFileSystemStore store
 backing this file system. | 
| org.apache.hadoop.fs.azure.AzureFileSystemThreadPoolExecutor | getThreadPoolExecutor(int threadCount,
                     String threadNamePrefix,
                     String operation,
                     String key,
                     String config) | 
| URI | getUri()Returns a URI which identifies this FileSystem. | 
| Path | getWorkingDirectory()Get the current working directory for the given FileSystem | 
| byte[] | getXAttr(Path path,
        String xAttrName)Get the value of an attribute for a path. | 
| boolean | hasPathCapability(Path path,
                 String capability)The base FileSystem implementation generally has no knowledge
 of the capabilities of actual implementations. | 
| void | initialize(URI uri,
          Configuration conf)Initialize a FileSystem. | 
| FileStatus[] | listStatus(Path f)Retrieve the status of a given path if it is a file, or of all the
 contained files if it is a directory. | 
| Path | makeAbsolute(Path path)Get the absolute version of the path (fully qualified). | 
| boolean | mkdirs(Path f,
      FsPermission permission)Make the given file and all non-existent parents into
 directories. | 
| boolean | mkdirs(Path f,
      FsPermission permission,
      boolean noUmask) | 
| static String | newMetricsSourceName()Creates a new metrics source name that's unique within this process. | 
| FSDataInputStream | open(Path f,
    int bufferSize)Opens an FSDataInputStream at the indicated Path. | 
| protected CompletableFuture<FSDataInputStream> | openFileWithOptions(Path path,
                   org.apache.hadoop.fs.impl.OpenFileParameters parameters)Execute the actual open file operation. | 
| String | pathToKey(Path path)Convert the path to a key. | 
| void | recoverFilesWithDanglingTempData(Path root,
                                Path destination)Looks under the given root path for any blob that are left "dangling",
 meaning that they are place-holder blobs that we created while we upload
 the data to a temporary blob, but for some reason we crashed in the middle
 of the upload and left them there. | 
| boolean | rename(Path src,
      Path dst)Renames Path src to Path dst. | 
| void | setOwner(Path p,
        String username,
        String groupname)Set owner of a path (i.e. | 
| void | setPermission(Path p,
             FsPermission permission)Set permission of a path. | 
| void | setWorkingDirectory(Path newDir)Set the working directory to the given directory. | 
| void | setXAttr(Path path,
        String xAttrName,
        byte[] value,
        EnumSet<XAttrSetFlag> flag)Set the value of an attribute for a path. | 
| void | updateWasbAuthorizer(org.apache.hadoop.fs.azure.WasbAuthorizerInterface authorizer) | 
append, append, append, append, appendFile, areSymlinksEnabled, cancelDeleteOnExit, canonicalizeUri, clearStatistics, closeAll, closeAllForUGI, completeLocalOutput, concat, copyFromLocalFile, copyFromLocalFile, copyFromLocalFile, copyFromLocalFile, copyToLocalFile, copyToLocalFile, copyToLocalFile, create, create, create, create, create, create, create, create, create, create, create, create, createBulkDelete, createDataOutputStreamBuilder, createFile, createMultipartUploader, createNewFile, createPathHandle, createSnapshot, createSnapshot, createSymlink, deleteOnExit, deleteSnapshot, enableSymlinks, exists, fixRelativePart, get, get, get, getAclStatus, getAllStatistics, getAllStoragePolicies, getBlockSize, getCanonicalUri, getContentSummary, getDefaultBlockSize, getDefaultBlockSize, getDefaultPort, getDefaultReplication, getDefaultReplication, getDefaultUri, getEnclosingRoot, getFileBlockLocations, getFileBlockLocations, getFileChecksum, getFileChecksum, getFileLinkStatus, getFileSystemClass, getFSofPath, getGlobalStorageStatistics, getInitialWorkingDirectory, getLength, getLinkTarget, getLocal, getName, getNamed, getPathHandle, getQuotaUsage, getReplication, getServerDefaults, getServerDefaults, getStatistics, getStatistics, getStatus, getStatus, getStoragePolicy, getStorageStatistics, getTrashRoot, getTrashRoots, getUsed, getUsed, getXAttrs, getXAttrs, globStatus, globStatus, isDirectory, isFile, listCorruptFileBlocks, listFiles, listLocatedStatus, listLocatedStatus, listStatus, listStatus, listStatus, listStatusIterator, listXAttrs, makeQualified, mkdirs, mkdirs, modifyAclEntries, moveFromLocalFile, moveFromLocalFile, moveToLocalFile, msync, newInstance, newInstance, newInstance, newInstanceLocal, open, open, open, openFile, openFile, openFileWithOptions, primitiveCreate, primitiveMkdir, primitiveMkdir, printStatistics, processDeleteOnExit, removeAcl, removeAclEntries, removeDefaultAcl, removeXAttr, rename, renameSnapshot, resolveLink, resolvePath, satisfyStoragePolicy, setAcl, setDefaultUri, setDefaultUri, setQuota, setQuotaByStorageType, setReplication, setStoragePolicy, setTimes, setVerifyChecksum, setWriteChecksum, setXAttr, startLocalOutput, supportsSymlinks, truncate, unsetStoragePolicygetConf, setConfpublic static final org.slf4j.Logger LOG
public static final String AZURE_CHOWN_USERLIST_PROPERTY_NAME
public static final String AZURE_DAEMON_USERLIST_PROPERTY_NAME
public static final String AZURE_CHMOD_USERLIST_PROPERTY_NAME
public static final String SKIP_AZURE_METRICS_PROPERTY_NAME
public static final String APPEND_SUPPORT_ENABLE_PROPERTY_NAME
public static final String RETURN_URI_AS_CANONICAL_SERVICE_NAME_PROPERTY_NAME
public static final String AZURE_RENAME_THREADS
public static final int DEFAULT_AZURE_RENAME_THREADS
public static final String AZURE_DELETE_THREADS
public static final int DEFAULT_AZURE_DELETE_THREADS
public static final String KEY_AZURE_AUTHORIZATION
public NativeAzureFileSystem()
public NativeAzureFileSystem(org.apache.hadoop.fs.azure.NativeFileSystemStore store)
public String getScheme()
FileSystem
 This implementation throws an UnsupportedOperationException.
getScheme in class FileSystempublic String getCanonicalServiceName()
getCanonicalServiceName in interface org.apache.hadoop.security.token.DelegationTokenIssuergetCanonicalServiceName in class FileSystemSecurityUtil.buildDTServiceName(URI, int)@VisibleForTesting public static String newMetricsSourceName()
protected void checkPath(Path path)
FileSystemcheckPath in class FileSystempath - to checkpublic void initialize(URI uri, Configuration conf) throws IOException, IllegalArgumentException
FileSysteminitialize in class FileSystemuri - a URI whose authority section names the host, port, etc.
   for this FileSystemconf - the configurationIOException - on any failure to initialize this instance.IllegalArgumentException - if the URI is considered invalid.public Path getHomeDirectory()
FileSystem"/user/$USER/".getHomeDirectory in class FileSystem@VisibleForTesting public void updateWasbAuthorizer(org.apache.hadoop.fs.azure.WasbAuthorizerInterface authorizer)
@VisibleForTesting public String pathToKey(Path path)
path - path converted to a key@VisibleForTesting public Path makeAbsolute(Path path)
path - path to be absolute path.@VisibleForTesting public org.apache.hadoop.fs.azure.AzureNativeFileSystemStore getStore()
public AzureFileSystemInstrumentation getInstrumentation()
public FSDataOutputStream append(Path f, int bufferSize, Progressable progress) throws IOException
append in class FileSystemf - the existing file to be appended.bufferSize - the size of the buffer to be used.progress - for reporting progress if it is not null.IOException - IO failurepublic FSDataOutputStream create(Path f, FsPermission permission, boolean overwrite, int bufferSize, short replication, long blockSize, Progressable progress) throws IOException
FileSystemcreate in class FileSystemf - the file name to openpermission - file permissionoverwrite - if a file with this name already exists, then if true,
   the file will be overwritten, and if false an error will be thrown.bufferSize - the size of the buffer to be used.replication - required block replication for the file.blockSize - block sizeprogress - the progress reporterIOException - IO failureFileSystem.setPermission(Path, FsPermission)public org.apache.hadoop.fs.azure.SelfRenewingLease acquireLease(Path path) throws AzureException
path - path whose lease to be renewed.AzureException - when not being able to acquire a lease on the pathpublic FSDataOutputStream createNonRecursive(Path f, FsPermission permission, boolean overwrite, int bufferSize, short replication, long blockSize, Progressable progress) throws IOException
FileSystemcreateNonRecursive in class FileSystemf - the file name to openpermission - file permissionoverwrite - if a file with this name already exists, then if true,
 the file will be overwritten, and if false an error will be thrown.bufferSize - the size of the buffer to be used.replication - required block replication for the file.blockSize - block sizeprogress - the progress reporterIOException - IO failureFileSystem.setPermission(Path, FsPermission)public FSDataOutputStream createNonRecursive(Path f, FsPermission permission, EnumSet<CreateFlag> flags, int bufferSize, short replication, long blockSize, Progressable progress) throws IOException
FileSystemcreateNonRecursive in class FileSystemf - the file name to openpermission - file permissionflags - CreateFlags to use for this stream.bufferSize - the size of the buffer to be used.replication - required block replication for the file.blockSize - block sizeprogress - the progress reporterIOException - IO failureFileSystem.setPermission(Path, FsPermission)public FSDataOutputStream createNonRecursive(Path f, boolean overwrite, int bufferSize, short replication, long blockSize, Progressable progress) throws IOException
FileSystemcreateNonRecursive in class FileSystemf - the file name to openoverwrite - if a file with this name already exists, then if true,
 the file will be overwritten, and if false an error will be thrown.bufferSize - the size of the buffer to be used.replication - required block replication for the file.blockSize - block sizeprogress - the progress reporterIOException - IO failureFileSystem.setPermission(Path, FsPermission)protected FSDataOutputStream createInternal(Path f, FsPermission permission, boolean overwrite, org.apache.hadoop.fs.azure.SelfRenewingLease parentFolderLease) throws FileAlreadyExistsException, IOException
f - the path to a file to be created.permission - for the newly created file.overwrite - specifies if the file should be overwritten.parentFolderLease - lease on the parent folder.IOException - if an IO error occurs while attempting to delete the
 path.FileAlreadyExistsException@Deprecated public boolean delete(Path path) throws IOException
FileSystemdelete in class FileSystempath - the path.IOException - IO failure.public boolean delete(Path f, boolean recursive) throws IOException
FileSystemdelete in class FileSystemf - the path to delete.recursive - if path is a directory and set to
 true, the directory is deleted else throws an exception. In
 case of a file the recursive can be set to either true or false.IOException - IO failurepublic boolean delete(Path f, boolean recursive, boolean skipParentFolderLastModifiedTimeUpdate) throws IOException
f - file path to be deleted.recursive - specify deleting recursively or not.skipParentFolderLastModifiedTimeUpdate - If true, don't update the folder last
 modified time.IOException - Thrown when fail to delete file or directory.public org.apache.hadoop.fs.azure.AzureFileSystemThreadPoolExecutor getThreadPoolExecutor(int threadCount,
                                                                                          String threadNamePrefix,
                                                                                          String operation,
                                                                                          String key,
                                                                                          String config)
public FileStatus getFileStatus(Path f) throws FileNotFoundException, IOException
FileSystemgetFileStatus in class FileSystemf - The path we want information fromFileNotFoundException - when the path does not existIOException - see specific implementationprotected boolean existsInternal(Path f) throws IOException
f - the path to a file or directory.IOException - if an IO error occurs while attempting to check
 for existence of the path.public URI getUri()
FileSystemgetUri in class FileSystempublic FileStatus[] listStatus(Path f) throws FileNotFoundException, IOException
listStatus in class FileSystemf - given pathFileNotFoundException - when the path does not existIOException - see specific implementationpublic boolean mkdirs(Path f, FsPermission permission) throws IOException
FileSystemmkdirs in class FileSystemf - path to createpermission - to apply to fIOException - IO failurepublic boolean mkdirs(Path f, FsPermission permission, boolean noUmask) throws IOException
IOExceptionpublic FSDataInputStream open(Path f, int bufferSize) throws FileNotFoundException, IOException
FileSystemopen in class FileSystemf - the file name to openbufferSize - the size of the buffer to be used.IOException - IO failureFileNotFoundExceptionprotected CompletableFuture<FSDataInputStream> openFileWithOptions(Path path, org.apache.hadoop.fs.impl.OpenFileParameters parameters) throws IOException
FileSystemFSDataInputStreamBuilder.build()
 and from DelegateToFileSystem and is where
 the action of opening the file should begin.
 The base implementation performs a blocking
 call to FileSystem.open(Path, int) in this call;
 the actual outcome is in the returned CompletableFuture.
 This avoids having to create some thread pool, while still
 setting up the expectation that the get() call
 is needed to evaluate the result.openFileWithOptions in class FileSystempath - path to the fileparameters - open file parameters from the builder.IOException - failure to resolve the link.public boolean rename(Path src, Path dst) throws FileNotFoundException, IOException
FileSystemrename in class FileSystemsrc - path to be renameddst - new path after renameIOException - on failureFileNotFoundExceptionpublic void setWorkingDirectory(Path newDir)
setWorkingDirectory in class FileSystemnewDir - Path of new working directorypublic Path getWorkingDirectory()
FileSystemgetWorkingDirectory in class FileSystempublic void setPermission(Path p, FsPermission permission) throws FileNotFoundException, IOException
FileSystemsetPermission in class FileSystemp - The pathpermission - permissionIOException - IO failureFileNotFoundExceptionpublic void setOwner(Path p, String username, String groupname) throws IOException
FileSystemsetOwner in class FileSystemp - The pathusername - If it is null, the original username remains unchanged.groupname - If it is null, the original groupname remains unchanged.IOException - IO failurepublic void setXAttr(Path path, String xAttrName, byte[] value, EnumSet<XAttrSetFlag> flag) throws IOException
setXAttr in class FileSystempath - The path on which to set the attributexAttrName - The attribute to setvalue - The byte value of the attribute to set (encoded in utf-8)flag - The mode in which to set the attributeIOException - If there was an issue setting the attribute on Azurepublic byte[] getXAttr(Path path, String xAttrName) throws IOException
getXAttr in class FileSystempath - The path on which to get the attributexAttrName - The attribute to getIOException - If there was an issue getting the attribute from Azurepublic void close()
           throws IOException
FileSystemFileSystem.deleteOnExit(Path), and remove this FS instance
 from the cache, if cached.
 After this operation, the outcome of any method call on this FileSystem
 instance, or any input/output stream created by it is undefined.close in interface Closeableclose in interface AutoCloseableclose in class FileSystemIOException - IO failurepublic Token<?> getDelegationToken(String renewer) throws IOException
getDelegationToken in interface org.apache.hadoop.security.token.DelegationTokenIssuerrenewer - the account name that is allowed to renew the token.IOException - thrown when getting the current user.public void access(Path path, FsAction mode) throws IOException
FileSystemAccessControlException.
 
 The default implementation calls FileSystem.getFileStatus(Path)
 and checks the returned permissions against the requested permissions.
 Note that the FileSystem.getFileStatus(Path) call will be subject to
 authorization checks.
 Typically, this requires search (execute) permissions on each directory in
 the path's prefix, but this is implementation-defined.  Any file system
 that provides a richer authorization model (such as ACLs) may override the
 default implementation so that it checks against that model instead.
 
 In general, applications should avoid using this method, due to the risk of
 time-of-check/time-of-use race conditions.  The permissions on a file may
 change immediately after the access call returns.  Most applications should
 prefer running specific file system actions as the desired user represented
 by a UserGroupInformation.
path - Path to checkmode - type of access to checkAccessControlException - if access is deniedFileNotFoundException - if the path does not existIOException - see specific implementationpublic void recoverFilesWithDanglingTempData(Path root, Path destination) throws IOException
root - The root path to consider.destination - The destination path to move any recovered files to.IOException - Thrown when fail to recover files.public void deleteFilesWithDanglingTempData(Path root) throws IOException
root - The root path to consider.IOException - Thrown when fail to delete.protected void finalize()
                 throws Throwable
@VisibleForTesting public String getOwnerForPath(Path absolutePath) throws IOException
IOExceptionpublic boolean hasPathCapability(Path path, String capability) throws IOException
FileSystemtrue, this instance is explicitly
 declaring that the capability is available.
 If the function returns false, it can mean one of:
 
 Implementors: PathCapabilitiesSupport
 can be used to help implement this method.
hasPathCapability in interface org.apache.hadoop.fs.PathCapabilitieshasPathCapability in class FileSystempath - path to query the capability of.capability - non-null, non-empty string to query the path for support.IOException - this should not be raised, except on problems
 resolving paths or relaying the call.Copyright © 2025 Apache Software Foundation. All rights reserved.