Powershell获取Exchange 邮箱用户配额
admin
2023-02-03 18:20:52
0
    客户场景:为很多用户单独配置过邮箱配额,想重新规划,现需要导致所有用户实际容量清单
    实现方式:直接上代码

#加载Exchange命令
Add-PSSnapin Microsoft.ex*
#主命令
[array]$output = "" | Select Name,ProhibitSendQuota,DBName
$DBs = Get-MailboxDatabase | Select Name,ProhibitSendQuota
foreach ($DB in $DBs) {
[string]$DBQuota = $DB.ProhibitSendQuota
[string]$DBName = $DB.Name
Write-Host "Database $DBName's quota is $DBQuota"
$Mails = Get-Mailbox -Database $DBName | Select Name,ProhibitSendQuota
foreach ($Mail in $Mails) {
if ($Mail.ProhibitSendQuota -eq "Unlimited") {
[string]$MailQuota = $DBQuota
}
else {
[string]$MailQuota = $Mail.ProhibitSendQuota
}

$Temp = "" | Select Name,ProhibitSendQuota,DBName
$Temp.Name = $Mail.Name
$Temp.ProhibitSendQuota = $MailQuota
$Temp.DBName = $DBName
#$Temp

$output += $Temp

}
}
$output | Export-Csv MailQuota.csv -NoTypeInformation -Encoding UTF8
输出结果:
Powershell获取Exchange 邮箱用户配额
与预期对比:
Powershell获取Exchange 邮箱用户配额
结论:如果为用户配置了不限制容量,则不能正常获取(客户实际环境中仅为董事长有配置无限制,手动修正,符合客户需求),欢迎帮解决此bug

    Update:
    客户提出了几点疑问:
    1. 这个结果我无法看出哪些用户是有手动配置过的
    2. 我不知道用户使用了多少,用了多少空间
    3. 需要最后登录时间
    4. 我有很多Mail Server,如果我只想获取一台怎么办?
    5. 我在C盘打开的这个脚本,但这个脚本实际位置在D盘,这个输出文件输出到了C盘怎么办?需要输出到脚本所在的目录

针对以上,优化了脚本:

  1. 先直接上脚本
    param($Server)
    $outfile = $(Split-Path -Parent $MyInvocation.MyCommand.Definition) + "\" + (Get-Date -UFormat "%Y-%m-%d_%H-%M-%S") + ".csv"
    Write-Host $outfile
    [array]$output = "" | Select Name,DBName,UserQuota,DBQuota,ProhibitSendQuota,TotalItemSize,Use,LastLogonTime
    #Select Name,DBName,UserQuota,DBQuota,ProhibitSendQuota,TotalItemSize,Use
    Add-PSSnapin Microsoft.ex
    if($Server){
    $DBs = Get-MailboxDatabase -Server $Server| Select Name,ProhibitSendQuota
    } else {
    $DBs = Get-MailboxDatabase | Select Name,ProhibitSendQuota
    }
    foreach ($DB in $DBs) {
    [string]$DBQuota = $DB.ProhibitSendQuota
    [string]$DBName = $DB.Name
    Write-Host "Database $DBName's quota is $DBQuota"
    $Mails = Get-Mailbox -Database $DBName -ResultSize unlimited | Select SamaccountName,ProhibitSendQuota
    foreach ($Mail in $Mails) {
    if ($Mail.ProhibitSendQuota -eq "Unlimited") {
    [string]$MailQuota = $DBQuota
    }
    else {
    [string]$MailQuota = $Mail.ProhibitSendQuota
    }
    $TotalItemSize = Get-MailboxStatistics -Identity $Mail.SamaccountName | select TotalItemSize,LastLogonTime
    $TempA = $Mail.ProhibitSendQuota
    $Temp = "" | Select Name,DBName,UserQuota,DBQuota,ProhibitSendQuota,TotalItemSize,Use,LastLogonTime
    $Temp.Name = $Mail.SamaccountName
    $Temp.DBName = $DBName
    if ($TempA -eq "Unlimited") {
    $Temp.UserQuota = $TempA
    } else {
    #$Temp.UserQuota = $TempA.replace(" ","").split("(")[0]
    $Temp.UserQuota = $($TempA -replace " ").Split("(")[0]
    }
    $Temp.DBquota = $($DBQuota -replace " ").Split("(")[0]
    $Temp.ProhibitSendQuota = $($MailQuota -replace " ").Split("(")[0]
    $Temp.TotalItemSize = $($TotalItemSize.TotalItemSize -replace " ").Split("(")[0]
    $Temp.Use = ('{0:n2}' -f $($Temp.TotalItemSize / $Temp.ProhibitSendQuota
    100)) +'%'
    $Temp.LastLogonTime = $TotalItemSize.LastLogonTime
    #$Temp

$output += $Temp

}
}
#$output[1..$output.count]
$output[1..$output.count] | Export-Csv $outfile -NoTypeInformation -Encoding UTF8 -Force

  1. 输出结果
    Powershell获取Exchange 邮箱用户配额
  2. 脚本执扫方式
    a. 直接执行则获取所有用户
    b. .\xxx.ps1 -Server XX则获取指定Server上的DB

欢迎补充

相关内容

热门资讯

德国总理:美国正在被伊朗羞辱 德国之声4月27日报道,德国总理默茨在访问一所学校时表示,在当前的持续冲突中,伊朗领导层正试图羞辱美...
理响中国|“长”歌以行,风云激... 光阴如梭,东方潮阔。这里是中国的长三角,世界的长三角。无论过去、现在还是未来,这片土地都因时代而生,...
白宫:特朗普及其国安团队开会讨... 新华社华盛顿4月27日电 美国白宫新闻秘书莱维特27日在记者会上证实,总统特朗普及其国家安全团队当天...
人民日报刊文:日本放开杀伤性武... 日本放开杀伤性武器出口推高地缘冲突风险(国际论坛)常思纯《人民日报》(2026年04月28日 第 0...
医疗保障法草案二审:明确生育保... 满足多样化健康保障需求本报记者 彭 波4月27日,医疗保障法草案二审稿提请十四届全国人大常委会第二十...
天津一景区发生自转旋翼机事故1... 澎湃新闻记者 吕新文中国民用航空华北地区管理局4月22日公布《豪客通航“10•1”天津长芦汉盐旅游区...
卡塔尔埃米尔与美国总统特朗普通... 当地时间24日,卡塔尔埃米尔塔米姆与美国总统特朗普通电话,重点就中东地区局势以及伊朗与美国谈判问题交...
男子30年前被扣押2859克黄... 澎湃新闻记者 王鑫家住辽宁省大连市的潘永嘉近日向澎湃新闻反映称,三十年前,他在大连周水子机场被盖州市...
商务部:取消反制欧盟两家金融机... 中华人民共和国商务部令二〇二六年 第1号鉴于欧盟已取消对中国两家金融机构的制裁措施,现公布《关于取消...
过去24小时共有5艘船只通过霍... 总台记者当地时间24日获悉,过去24小时内,共有5艘船只通过霍尔木兹海峡,其中包括一艘伊朗油轮。(总...