[玩转系统] 在 PowerShell 中检索大量用户的邮箱统计信息
作者:精品下载站 日期:2024-12-14 07:09:33 浏览:13 分类:玩电脑
在 PowerShell 中检索大量用户的邮箱统计信息
我目前正在开展一个项目,我们要将 24,000 个邮箱从 Exchange 2016 迁移到 Exchange Online。出于规划目的,我们希望了解基本统计数据,例如 LastLogonTime 和项目数量(常规项目和已删除项目)。
要为我的邮箱检索此信息,您可以使用如下内容:
[PS] C:\ >Get-Mailbox -Identity wesseliusj | Get-MailboxStatistics | Select DisplayName,LastLogonTime,ItemCount,TotalItemSize,DeletedItemsCount,TotalDeletedItemSize
DisplayName : Wesselius, J
LastLogonTime : 28-4-2022 11:24:46
ItemCount : 1065
TotalItemSize : 63.95 MB (67,060,296 bytes)
DeletedItemsCount :
TotalDeletedItemSize : 5.421 MB (5,684,477 bytes)
TotalItemSize 和 TotalDeletedItemSize 以文本而非数字形式返回。由于我想将所有内容导出到 CSV 文件并导入到 Excel 中进行进一步处理,因此必须将其转换为数值。这称为计算属性,可以使用以下选项实现:
@{Name="TotalItemSizeMB";Expression={$_.TotalItemSize.Value.ToBytes()}}
ToBytes() 也可以是 ToKB()、ToMB() 或 ToGB(),具体取决于您的情况。
之前的命令和输出现在将如下所示:
[PS] C:\>Get-Mailbox -Identity wesseliusj | Get-MailboxStatistics | Select DisplayName,LastLogonTime,ItemCount,@{Name="TotalItemSizeMB";Expression={$_.TotalItemSize.Value.ToBytes()}},DeletedItemsCount,@{Name="TotalDeletedItemSizeMB";Expression={$_.TotalDeletedItemSize.Value.ToBytes()}}
DisplayName : Wesselius, J
LastLogonTime : 28-4-2022 11:24:46
ItemCount : 1065
TotalItemSizeMB : 67060293
DeletedItemsCount :
TotalDeletedItemSizeMB : 5684477
现在使用 Export-Csv 命令,我们就可以开始了(你会希望?):
[PS] C:\>get-mailbox -ResultSize unlimited | Get-MailboxStatistics | Select DisplayName,LastLogonTime,ItemCount,@{Name="TotalItemSizeMB";Expression={$_.TotalItemSize.Value.ToBytes()}},DeletedItemsCount,@{Name="TotalDeletedItemSizeMB";Expression={$_.TotalDeletedItemSize.Value.ToBytes()}} | export-csv -Path statistics.csv -nti
Sending data to a remote command failed with the following error message: [ClientAccessServer=EXCH2016,BackEndServer=exch2016.labs.local,RequestId=c0430cd6-6f4d-48a5-8434-d59ebcd91887,TimeStamp=28-4-2022 10:03:54] [FailureCategory=W
SMan-Others] The total data received from the remote client exceeded the allowed maximum. The allowed maximum is 524288000. For more information, see the about_Remote_Troubleshooting Help topic.
+ CategoryInfo : OperationStopped: (exch2016.labs.local:String) [], PSRemotingTransportException
+ FullyQualifiedErrorId : JobFailure
+ PSComputerName : exch2016.labs.local
[PS] C:\>
不幸的是,Get-Mailbox 命令在一次运行中检索了所有 24,000 个邮箱,然后尝试将其用作 Get-MailboxStatistics 命令的输入。虽然这仅适用于少数邮箱,但对于大量邮箱来说,它会耗尽内存。
这里的解决方案(或解决方案之一)是将所有邮箱导入到一个变量中,并结合 Get-MailboxStatistics 命令循环遍历该变量中的所有邮箱:
[PS] C:\> $Mailboxes = Get-Mailbox -Resultsize Unlimited
[PS] C:\> ForEach ($Mailbox in $Mailboxes) {Get-MailboxStatistics $Mailbox | Select DisplayName,LastLogonTime,ItemCount,@{Name="TotalItemSizeMB";Expression={$_.TotalItemSize.Value.ToBytes()}},DeletedItemsCount,@{Name="TotalDeletedItemSizeMB";Expression={$_.TotalDeletedItemSize.Value.ToBytes()}} | export-csv -Path statistics.csv -nti}
我遇到的最后一个问题是将用户的 UPN 或别名添加到 CSV 文件中。 UPN 和别名不在 Get-MailboxStatistics 返回的对象中,但由 Get-Mailbox 命令返回。要在输出中获取这些属性,必须再次使用计算属性,类似于之前使用的大小属性。
要检索 UPN,请使用类似于以下内容的内容:
@{Name = "UPN"; Expression={$Mailbox.UserPrincipalName}}
这将获取第一个命令 (Get-Mailbox) 的 UserPrincipalName 属性并将其解析到输出中。整个命令将是:
[PS] C:\>ForEach ($Mailbox in $Mailboxes) {Get-MailboxStatistics $Mailbox | Select DisplayName, @{Name = "UPN"; Expression={$Mailbox.UserPrincipalName}},LastLogonTime,ItemCount,@{Name="TotalItemSizeMB";Expression={$_.TotalItemSize.Value.To
Bytes()}},DeletedItemsCount,@{Name="TotalDeletedItemSizeMB";Expression={$_.TotalDeletedItemSize.Value.ToBytes()}}}
DisplayName : Wesselius, J
UPN : j.wesselius@Exchangelabs.nl
LastLogonTime : 29-4-2022 14:22:03
ItemCount : 1098
TotalItemSizeMB : 68714749
DeletedItemsCount :
TotalDeletedItemSizeMB : 5822787
[PS] C:\>
这将创建一个正确的 CSV 文件,其中包含我需要的所有信息,准备导入到 Excel 中?
有关处理大量用户(在 Office 365 中)的更多信息,请查看以下文章:在 Office 365 中为大量用户运行 PowerShell cmdlet - Microsoft 技术社区
猜你还喜欢
- 03-30 [玩转系统] 如何用批处理实现关机,注销,重启和锁定计算机
- 02-14 [系统故障] Win10下报错:该文件没有与之关联的应用来执行该操作
- 01-07 [系统问题] Win10--解决锁屏后会断网的问题
- 01-02 [系统技巧] Windows系统如何关闭防火墙保姆式教程,超详细
- 12-15 [玩转系统] 如何在 Windows 10 和 11 上允许多个 RDP 会话
- 12-15 [玩转系统] 查找 Exchange/Microsoft 365 中不活动(未使用)的通讯组列表
- 12-15 [玩转系统] 如何在 Windows 上安装远程服务器管理工具 (RSAT)
- 12-15 [玩转系统] 如何在 Windows 上重置组策略设置
- 12-15 [玩转系统] 如何获取计算机上的本地管理员列表?
- 12-15 [玩转系统] 在 Visual Studio Code 中连接到 MS SQL Server 数据库
- 12-15 [玩转系统] 如何降级 Windows Server 版本或许可证
- 12-15 [玩转系统] 如何允许非管理员用户在 Windows 中启动/停止服务
取消回复欢迎 你 发表评论:
- 精品推荐!
-
- 最新文章
- 热门文章
- 热评文章
[影视] 黑道中人 Alto Knights(2025)剧情 犯罪 历史 电影
[古装剧] [七侠五义][全75集][WEB-MP4/76G][国语无字][1080P][焦恩俊经典]
[实用软件] 虚拟手机号 电话 验证码 注册
[电视剧] 安眠书店/你 第五季 You Season 5 (2025) 【全10集】
[电视剧] 棋士(2025) 4K 1080P【全22集】悬疑 犯罪 王宝强 陈明昊
[软件合集] 25年6月5日 精选软件22个
[软件合集] 25年6月4日 精选软件36个
[短剧] 2025年06月04日 精选+付费短剧推荐33部
[短剧] 2025年06月03日 精选+付费短剧推荐25部
[软件合集] 25年6月3日 精选软件44个
[剧集] [央视][笑傲江湖][2001][DVD-RMVB][高清][40集全]李亚鹏、许晴、苗乙乙
[电视剧] 欢乐颂.5部全 (2016-2024)
[电视剧] [突围] [45集全] [WEB-MP4/每集1.5GB] [国语/内嵌中文字幕] [4K-2160P] [无水印]
[影视] 【稀有资源】香港老片 艺坛照妖镜之96应召名册 (1996)
[剧集] 神经风云(2023)(完结).4K
[剧集] [BT] [TVB] [黑夜彩虹(2003)] [全21集] [粤语中字] [TV-RMVB]
[实用软件] 虚拟手机号 电话 验证码 注册
[资源] B站充电视频合集,包含多位重量级up主,全是大佬真金白银买来的~【99GB】
[影视] 内地绝版高清录像带 [mpg]
[书籍] 古今奇书禁书三教九流资料大合集 猎奇必备珍藏资源PDF版 1.14G
[电视剧] [突围] [45集全] [WEB-MP4/每集1.5GB] [国语/内嵌中文字幕] [4K-2160P] [无水印]
[剧集] [央视][笑傲江湖][2001][DVD-RMVB][高清][40集全]李亚鹏、许晴、苗乙乙
[电影] 美国队长4 4K原盘REMUX 杜比视界 内封简繁英双语字幕 49G
[电影] 死神来了(1-6)大合集!
[软件合集] 25年05月13日 精选软件16个
[精品软件] 25年05月15日 精选软件18个
[绝版资源] 南与北 第1-2季 合集 North and South (1985) /美国/豆瓣: 8.8[1080P][中文字幕]
[软件] 25年05月14日 精选软件57个
[短剧] 2025年05月14日 精选+付费短剧推荐39部
[短剧] 2025年05月15日 精选+付费短剧推荐36部
- 最新评论
-
- 热门tag