Exchange 2010 TotalItemSize.Value.ToBytes()始终为空

时间:2010-07-01 09:04:12

标签: powershell exchange-server-2010

我正在尝试创建有关Exchange 2010邮箱大小的简单报告。

虽然这有效:

Get-MailboxStatistics -server <serverfqdn> |ft  displayname, TotalItemSize

这不会(第二列保持空白):

Get-MailboxStatistics -server <serverfqdn> |ft  displayname, {$_.TotalItemSize.Value.ToBytes()}

问题是我需要将大小作为整数,因此第一行代码不符合我的目的。 根据几个网站,第二行代码工作,但不幸的是我的机器上没有。

我知道我可以在使用第一行后解析该值,但这会不必要地效率低下,不是吗? : - )

希望任何人都可以提供帮助。

此致 凯文

10 个答案:

答案 0 :(得分:2)

这对我有用

$a = get-mailbox -id user | Get-MailboxStatistics 

$a.TotalItemSize.Value.ToMB()

$a.TotalItemSize.Value.ToKB()

答案 1 :(得分:2)

如果从导入的PS会话执行,则类型变为自定义对象时,方法.ToMB()将丢失。 $ variable.TotalItemSize.Value变为两个元素数组[0],以KB,MB或GB为单位,[1]总是以字节为单位。

因此,为了使用这个,我们可以使用字符串来实现我们想要的东西..为了清晰起见,我们可以长期使用

$mailboxes = Get-Mailbox -Filter{(RecipientType -eq "UserMailbox") -and (CustomAttribute12 -eq "whatever")}
foreach ($mailbox in $mailboxes)
{
$size1 = Get-MailboxStatistics $mailbox.id 
[string]$bob = $size1.TotalItemSize.Value
[int]$bill = $bob.TrimEnd(" bytes)").Split("(")[1] # The bytes part of the array.
$bill = $bill/1mb # Convert into MB's
if ($bill -le 1500) {do something} Else {"Too Big " + $bill} # note -le 1500 NOT 1500MB

}

我希望这会有所帮助

答案 2 :(得分:1)

我有同样的问题。我不确定你是否解决了这个问题。 我有这个,这很难看 - 但是有效:

$a = get-mailbox USER | get-mailboxstatistics
$intTotalItemSize = [int]$a.TotalItemSize.SubString($a.TotalItemSize.indexof("(")+1, $a.TotalItemSize.indexof(" b")-$a.TotalItemSize.indexof("("))

答案 3 :(得分:0)

尝试使用此尺寸表达式:

@{expression={$_.TotalItemSize.Value.ToMB()};label="Mailbox Size(MB)"}

我相信还有ToKB()方法。

答案 4 :(得分:0)

MVP Shay Levy在他的博客上深入研究过这个问题(http://blogs.microsoft.co.il/blogs/scriptfanatic/archive/2011/08/22/get-full-control-over-your-exchange-远程的powershell-session.aspx)。

基本上,您必须修改要远程连接的服务器上的PowerShell虚拟目录中的设置。

对于那些远程访问Exchange服务器的人来说,这是一个好消息,但是对于那些使用托管Exchange解决方案并且无法更改这些设置的人来说,这对我们这些人没有帮助。我想我们将不得不放弃PowerShell的一些超级酷,然后回到解析字符串以获取字节并从那里转换。

- 编辑 -

这就是我处理输出所有用户邮箱大小的文件的方法。它可以进一步压缩,但这种方式更具可读性。

$allMailboxes = Get-Mailbox -ResultSize Unlimited

ForEach ( $mailbox in $allMailboxes ) {
    $itemSizeString = ( Get-MailboxStatistics $mailbox.Identity ).TotalItemSize.Value.ToString()
    $posOpenParen = $itemSizeString.IndexOf("(") + 1
    $numCharsInSize = $itemSizeString.IndexOf(" bytes") - $posOpenParen 
    $mailboxSizeInBytes = $itemSizeString.SubString($posOpenParen,$numCharsInSize).Replace(",","")

    Write-Output "$($mailbox.alias),$($mailboxSizeInBytes)"
}

答案 5 :(得分:0)

请参阅此文章:http://blogs.technet.com/b/gary/archive/2010/02/20/the-get-mailboxstatistics-cmdlet-the-totalitemsize-property-and-that-pesky-little-b.aspx

Get-Mailbox | Get-MailboxStatistics | Add-Member -MemberType ScriptProperty -Name TotalItemSizeinMB -Value {$this.totalitemsize.value.ToMB()} -PassThru | Format-Table DisplayName,TotalItem*

答案 6 :(得分:0)

我需要在远程会话之外完成这项工作,所以我将Greybear的答案简化为:

$a = get-mailbox USER | get-mailboxstatistics
$intTotalItemSize = [int64]($a.TotalItemSize -split '[\( ]')[3]

或者以原始问题的格式::

Get-MailboxStatistics -Server <serverfqdn> | Select-Object -Property DisplayName,@{label="TotalItemSize";expression={[int64]($_.TotalItemSize -split '[\( ]')[3]}} | ft

意识到[int]对于超过4GB的邮箱会失败,因此更改为[int64]。或者,以MB为单位显示邮箱:

Get-MailboxStatistics -Server <serverfqdn> | Select-Object -Property DisplayName,@{label="TotalItemSize";expression={[int64](([int64]($_.TotalItemSize -split '[\( ]')[3])/1048576)}} | ft

答案 7 :(得分:0)

名称需要在表达式之前。这将有效。

Get-MailboxStatistics -Identity [name] | select @{label=”User”;expression={$_.DisplayName}},lastlogontime,@{label=”Total Size (MB)”;expression={$_.TotalItemSize.Value.ToMB()}}

答案 8 :(得分:0)

这对我有用

@{Name="TotalSize (MB)"; Expression={((($_.TotalItemSize) -split " ")[0])}}

答案 9 :(得分:-1)

您可以尝试:

get-mailbox -resultsize unlimited | Get-MailboxStatistics | ft displayname,@{label="Total Size (MB)";expression={$_.TotalItemSize.Value.ToMB()}}