使用 PowerShell 管理 Azure Data Lake Storage 中的目錄和檔案
本文說明如何使用 PowerShell 在具有階層命名空間的儲存體帳戶中建立及管理目錄和檔案。
若要瞭解如何取得、設定及更新目錄和檔案的訪問控制清單(ACL),請參閱 使用 PowerShell 來管理 Azure Data Lake Storage 中的 ACL。
參考 | Gen1 至 Gen2 對應 | 提供意見反應
必要條件
Azure 訂用帳戶。 如需詳細資訊,請參閱取得 Azure 免費試用。
已啟用階層命名空間的儲存體帳戶。 遵循下列指示以建立帳戶。
已安裝 .NET Framework 4.7.2 或更高版本。 如需詳細資訊,請參閱下載 .NET Framework。
PowerShell
5.1
版或更高版本。
安裝 PowerShell 模組
使用下列命令,確認已安裝的 PowerShell 版本為
5.1
或更高版本。echo $PSVersionTable.PSVersion.ToString()
若要升級您的 PowerShell 版本,請參閱升級現有的 Windows PowerShell
安裝 Az.Storage 模組。
Install-Module Az.Storage -Repository PSGallery -Force
如需如何安裝 PowerShell 模組的詳細資訊,請參閱安裝 Azure PowerShell 模組
連線到帳戶
開啟 Windows PowerShell 命令視窗,然後使用 Connect-AzAccount 命令登入您的 Azure 訂用 帳戶 ,然後遵循螢幕上的指示。
Connect-AzAccount
如果您的身分識別與一個以上的訂用帳戶相關聯,且系統不會提示您選取訂用帳戶,請將作用中的訂用帳戶設定為您要操作之記憶體帳戶的訂用帳戶。 在此範例中,使用訂用帳戶識別碼取代
<subscription-id>
預留位置值。Select-AzSubscription -SubscriptionId <subscription-id>
取得儲存體帳戶內容。
$ctx = New-AzStorageContext -StorageAccountName '<storage-account-name>' -UseConnectedAccount
建立容器
容器可作為您檔案的檔案系統。 您可以使用 New-AzStorageContainer Cmdlet 來建立一個。
此範例會建立名為 my-file-system
的容器。
$filesystemName = "my-file-system"
New-AzStorageContainer -Context $ctx -Name $filesystemName
建立目錄
使用 New-AzDataLakeGen2Item Cmdlet 建立目錄參考。
此範例會將名為 my-directory
的目錄新增至容器。
$filesystemName = "my-file-system"
$dirname = "my-directory/"
New-AzDataLakeGen2Item -Context $ctx -FileSystem $filesystemName -Path $dirname -Directory
此範例會新增相同的目錄,但也會設定權限、umask、屬性值和中繼資料值。
$dir = New-AzDataLakeGen2Item -Context $ctx -FileSystem $filesystemName -Path $dirname -Directory -Permission rwxrwxrwx -Umask ---rwx--- -Property @{"ContentEncoding" = "UDF8"; "CacheControl" = "READ"} -Metadata @{"tag1" = "value1"; "tag2" = "value2" }
顯示目錄屬性
此範例會使用 Get-AzDataLakeGen2Item Cmdlet 取得目錄,然後將屬性值列印至主控台。
$filesystemName = "my-file-system"
$dirname = "my-directory/"
$dir = Get-AzDataLakeGen2Item -Context $ctx -FileSystem $filesystemName -Path $dirname
$dir.ACL
$dir.Permissions
$dir.Group
$dir.Owner
$dir.Properties
$dir.Properties.Metadata
注意
若要取得容器的根目錄,請省略 -Path
參數。
重新命名目錄或移動目錄
使用 Move-AzDataLakeGen2Item Cmdlet 重新命名或行動目錄。
此範例會將名稱為 my-directory
的目錄重新命名為 my-new-directory
。
$filesystemName = "my-file-system"
$dirname = "my-directory/"
$dirname2 = "my-new-directory/"
Move-AzDataLakeGen2Item -Context $ctx -FileSystem $filesystemName -Path $dirname -DestFileSystem $filesystemName -DestPath $dirname2
注意
若要在不提示的情況下進行覆寫,請使用 -Force
參數。
此範例會將名為 my-directory
的目錄移至 my-directory-2
的子目錄 (名為 my-subdirectory
)。
$filesystemName = "my-file-system"
$dirname = "my-directory/"
$dirname2 = "my-directory-2/my-subdirectory/"
Move-AzDataLakeGen2Item -Context $ctx -FileSystem $filesystemName -Path $dirname -DestFileSystem $filesystemName -DestPath $dirname2
刪除目錄
使用 Remove-AzDataLakeGen2Item Cmdlet 刪除目錄。
此範例刪除名為 my-directory
的目錄。
$filesystemName = "my-file-system"
$dirname = "my-directory/"
Remove-AzDataLakeGen2Item -Context $ctx -FileSystem $filesystemName -Path $dirname
您可以使用 -Force
參數來移除檔案,而不需要提示。
從目錄下載
使用 Get-AzDataLakeGen2ItemContent Cmdlet 從目錄下載檔案。
此範例從名為 my-directory
的目錄下載名為 upload.txt
的檔案。
$filesystemName = "my-file-system"
$filePath = "my-directory/upload.txt"
$downloadFilePath = "download.txt"
Get-AzDataLakeGen2ItemContent -Context $ctx -FileSystem $filesystemName -Path $filePath -Destination $downloadFilePath
列出目錄內容
使用 Get-AzDataLakeGen2ChildItem Cmdlet 列出目錄的內容。 您可以使用選擇性參數 -OutputUserPrincipalName
來取得使用者的名稱 (而不是物件識別碼)。
此範例會列出名為 my-directory
的目錄所含的內容。
$filesystemName = "my-file-system"
$dirname = "my-directory/"
Get-AzDataLakeGen2ChildItem -Context $ctx -FileSystem $filesystemName -Path $dirname -OutputUserPrincipalName
下列範例會列出目錄中每個項目的 ACL
、Permissions
、Group
和 Owner
屬性。 必須要有 -FetchProperty
參數才能取得 ACL
屬性的值。
$filesystemName = "my-file-system"
$dirname = "my-directory/"
$properties = Get-AzDataLakeGen2ChildItem -Context $ctx -FileSystem $filesystemName -Path $dirname -Recurse -FetchProperty
$properties.ACL
$properties.Permissions
$properties.Group
$properties.Owner
注意
若要列出容器根目錄的內容,請省略 -Path
參數。
將檔案上傳至目錄
使用 New-AzDataLakeGen2Item Cmdlet 將檔案上傳至目錄。
此範例將名為 upload.txt
的檔案上傳至名為 my-directory
的目錄。
$localSrcFile = "upload.txt"
$filesystemName = "my-file-system"
$dirname = "my-directory/"
$destPath = $dirname + (Get-Item $localSrcFile).Name
New-AzDataLakeGen2Item -Context $ctx -FileSystem $filesystemName -Path $destPath -Source $localSrcFile -Force
此範例會上傳相同的檔案,但接著會設定目的地檔案的權限、umask、屬性值和中繼資料值。 此範例也會將這些值列印至主控台。
$file = New-AzDataLakeGen2Item -Context $ctx -FileSystem $filesystemName -Path $destPath -Source $localSrcFile -Permission rwxrwxrwx -Umask ---rwx--- -Property @{"ContentEncoding" = "UDF8"; "CacheControl" = "READ"} -Metadata @{"tag1" = "value1"; "tag2" = "value2" }
$file1
$file1.Properties
$file1.Properties.Metadata
注意
若要將檔案上傳至容器的根目錄,請省略 -Path
參數。
顯示檔案屬性
此範例會使用 Get-AzDataLakeGen2Item Cmdlet 取得檔案,然後將屬性值列印至主控台。
$filepath = "my-directory/upload.txt"
$filesystemName = "my-file-system"
$file = Get-AzDataLakeGen2Item -Context $ctx -FileSystem $filesystemName -Path $filepath
$file
$file.ACL
$file.Permissions
$file.Group
$file.Owner
$file.Properties
$file.Properties.Metadata
刪除檔案
使用 Remove-AzDataLakeGen2Item Cmdlet 刪除檔案。
此範例會刪除名為 upload.txt
的檔案。
$filesystemName = "my-file-system"
$filepath = "upload.txt"
Remove-AzDataLakeGen2Item -Context $ctx -FileSystem $filesystemName -Path $filepath
您可以使用 -Force
參數來移除檔案,而不需要提示。
Gen1 至 Gen2 對應
下表顯示 Data Lake Storage Gen1 所使用的 Cmdlet 如何對應至 Data Lake Storage 的 Cmdlet。
注意
Azure Data Lake Storage Gen1 現已淘汰。 請參閱這裡的淘汰公告。 Data Lake Storage Gen1 資源無法再存取。 如果您需要特殊協助,請 與我們連絡。
Data Lake Storage Gen1 Cmdlet | Data Lake Storage Cmdlet | 備註 |
---|---|---|
Get-AzDataLakeStoreChildItem | Get-AzDataLakeGen2ChildItem | 根據預設,Get-AzDataLakeGen2ChildItem Cmdlet 只會列出第一個層級的子項目。 -Recurse 參數會以遞迴方式列出子項目。 |
Get-AzDataLakeStoreItem Get-AzDataLakeStoreItemAclEntry Get-AzDataLakeStoreItemOwner Get-AzDataLakeStoreItemPermission |
Get-AzDataLakeGen2Item | Get-AzDataLakeGen2Item Cmdlet 的輸出項目具有下列屬性:ACL、擁有者、群組、權限。 |
Get-AzDataLakeStoreItemContent | Get-AzDataLakeGen2FileContent | Get-AzDataLakeGen2FileContent Cmdlet 會將檔案內容下載至本機檔案。 |
Move-AzDataLakeStoreItem | Move-AzDataLakeGen2Item | |
New-AzDataLakeStoreItem | New-AzDataLakeGen2Item | 此 Cmdlet 會從本機檔案上傳新的檔案內容。 |
Remove-AzDataLakeStoreItem | Remove-AzDataLakeGen2Item | |
Set-AzDataLakeStoreItemOwner Set-AzDataLakeStoreItemPermission Set-AzDataLakeStoreItemAcl |
Update-AzDataLakeGen2Item | Update-AzDataLakeGen2Item Cmdlet 只會更新單一項目,而不會以遞迴方式更新。 如果要以遞迴方式更新,請使用 Get-AzDataLakeStoreChildItem Cmdlet 列出項目,然後再透過管線將其傳送至 Update-AzDataLakeGen2Item Cmdlet。 |
Test-AzDataLakeStoreItem | Get-AzDataLakeGen2Item | 如果項目不存在,Get-AzDataLakeGen2Item Cmdlet 會回報錯誤。 |