亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

PowerShell 修復 Robocopy的權限問題

發布時間:2020-07-16 22:06:27 來源:網絡 閱讀:2354 作者:beanxyz 欄目:系統運維

最近豆子公司在轉移文件服務器,大概有80T的文件需要傳送到云端。豆子直接使用了robocopy進行拷貝。因為歷史原因,有些文件夾的權限設置比較奇葩,導致豆子的賬戶也沒有權限去訪問,這樣的結果就是Robocopy里面可能會有幾十百甚至上千個文件夾因為權限問題而無法拷貝。


robocopy 命令例子

robocopy c:\source  d:\destination /E /w:30 /r:3 /log+:"c:\temp\log.txt" /xf .*


那么如果解決這個問題呢?豆子的思路是獲取robocopy的日志文件,通過正則提取其中失敗的路徑,然后通過腳本重新奪取管理員權限,然后重新賦予NTFS的權限。


比如說,下面的robocopy 日志,報錯信息如下所示

  New Dir          0\\syd02\Track\.TemporaryItems\folders.1138144168\Cleanup At Startup\.BAH.FftCc\
2017/11/12 08:58:18 ERROR 5 (0x00000005) Scanning Source Directory \\syd02\Track\.TemporaryItems\folders.1138144168\Cleanup At Startup\.BAH.FftCc\Altitude Business Card Visuals\
Access is denied.
Waiting 180 seconds... Retrying...
2017/11/12 09:01:18 ERROR 5 (0x00000005) Scanning Source Directory \\syd02\Track\.TemporaryItems\folders.1138144168\Cleanup At Startup\.BAH.FftCc\Altitude Business Card Visuals\
Access is denied.
ERROR: RETRY LIMIT EXCEEDED.


提取路徑的PowerShell腳本如下:

#Read robocopy log files
$contents=gc C:\temp\tracktransfer.txt -raw
#Regular Expression Pattern
$patt='(\\\\syd02.*\n)Access is denied'
$result=@()
#Distract the path of broken folders
$contents | select-string -Pattern $patt -AllMatches | 
foreach {
$result+=$_.matches.groups | Where-Object {$_.name -eq 1}| select -ExpandProperty value
}

#remove duplicated record and blank lines
$result |sort -Unique | foreach {$_.trimend()} | where{$_ -ne ""} | set-content c:\temp\list.txt

生成的文本文件如下所示:


list.txt

\\syd02\Track\CLIENTS\WESTPAC\Westpac Cards\1_Acquisition\FY 17\Q1 Campaigns\WBCCAR7498 Q1.1 Campaign\PRODUCTION\
\\syd02\Track\.TemporaryItems\folders.1138144168\Cleanup At Startup\.BAH.FftCc\Altitude Business Card Visuals\
\\syd02\Track\CLIENTS\WESTPAC\Westpac Cards\1_Acquisition\FY 17\Q1 Campaigns\WBCCAR7487 Q1 OOH - Low Rate\CREATIVE\
\\syd02\Track\.TemporaryItems\folders.1138144168\Cleanup At Startup\.BAH.cj82c\Westpac Brand assets\
\\syd02\Track\CLIENTS\WESTPAC\Westpac Cards\2_Lifecycle\WBCCAR7602 Additional Cardholder\COPY\
\\syd02\Track\CLIENTS\WESTPAC\Westpac Cards\2_Lifecycle\WBCCAR7602 Additional Cardholder\PRODUCTION\
\\syd02\Track\CLIENTS\WESTPAC\Westpac CRM\Business\3. COMPLETE\2016\WBCCRM7595_Q4 SME Relationship email\CREATIVE\FINAL\Individual modules\Modules Half Width\
\\syd02\Track\CLIENTS\WESTPAC\Westpac Cards\1_Acquisition\FY 17\Q2 Campaigns\WBCCAR7516 Microsite Optimisation\FINANCE\
\\syd02\Track\CLIENTS\WESTPAC\Westpac Cards\1_Acquisition\FY 17\Q1 Campaigns\WBCCAR7487 Q1 OOH - Low Rate\FINANCE\


因為最近在復習Python,順手又用Python寫了一個同樣的功能,效果是一樣的

fp=open('c:/temp/tracktransfer.txt')
fp2=open('c:/temp/list.txt','w')
contents=fp.read()
pat=r'(\\\\syd02.*\n)Access is denied'
ret=re.findall(pat,contents)
ret=set(ret)
for item in ret:
    print(item)
    fp2.write(item)
print("total number is %d"%len(ret))
fp.close()
fp2.close()


-----------------------


然后接下來是重頭戲,如何重新奪取權限和賦值?

PowerShell自帶的Get-ACL和Set-ACL命令,以及DOS命令 takeown我都試過,老實說,不太好使,后來很幸運地在網上發現了一個第三方的模塊 NTFSSecurity,里面的函數完全實現了我需要的功能。

下載地址:

https://gallery.technet.microsoft.com/scriptcenter/1abd77a5-9c0b-4a2b-acef-90dbb2b84e85#content


下載之后,直接解壓到對應的Powershell模塊路徑,然后重啟PowerShell ISE就可以自動加載了。


下面是后半截代碼,修改目標目錄及其子目錄文件的所有者和訪問權限

$a = Get-Content "C:\temp\list.txt"
#For each folder and subfolders, setup the ownership and NTFS permissions
foreach ($i in $a)
{
    if(test-path $i)
  {
        write-host Taking ownership of Directory $i -fore Green 
        get-item $i | Set-NTFSOwner -Account 'omnicom\group Australia it access'
        get-item $i | add-ntfsaccess -account 'omnicom\group Australia it access' -Acce***ights FullControl
        get-item $i | Add-NTFSAccess -Account 'omnicom\sydney track all staff' -Acce***ights modify
 
        $items = @()
        $items = $null
        $path = $null
        #if need to setup all subfolders, we can use -recusrse in the following cmdlet.
        $items = get-childitem $i -force
        foreach($item in $items)
            {
                $path = $item.FullName
                Write-Host ...Adding AdminGroup to $path -Fore Green
                Get-Item -force $path | Set-NTFSOwner -Account 'omnicom\group Australia it access'
                get-item $item | Add-NTFSAccess -account 'omnicom\group Australia it access' -Acce***ights FullControl
                get-item $item | Add-NTFSAccess -Account 'omnicom\sydney track all staff' -Acce***ights modify
            }
   }
}


最后的效果是


PowerShell 修復 Robocopy的權限問題


這樣子,如果RoboCopy出了什么權限方面的問題,我通過這個腳本就可以很容易的解決了,一次不行,修復之后再跑一次Robocopy很快就可以把丟失的文件拷貝回來了~

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

娱乐| 大悟县| 遵化市| 蓬溪县| 儋州市| 盖州市| 河东区| 周口市| 商南县| 苗栗市| 灵川县| 屯门区| 南平市| 宁晋县| 东阿县| 随州市| 成武县| 保定市| 阳新县| 白玉县| 沅江市| 利津县| 通化县| 五家渠市| 福贡县| 洛阳市| 新乐市| 米脂县| 仙桃市| 葫芦岛市| 通州区| 郓城县| 两当县| 沾化县| 申扎县| 龙江县| 石首市| 佛坪县| 营口市| 休宁县| 英德市|