Тематические термины: Exchange, Powershell.
Описанные методы помогут собрать статистику об отправленных и полученных сообщениях, найти нужное письмо или решить проблему с отправкой сообщений.
Стоит сразу предупредить — метод не удобен для большого числа писем. Его стоит применять для общего ознакомления работы со статистикой или с применением фильтров.
Открываем Консоль управления Exchange – переходим в Инструменты – Проводник журнала отслеживания:
Ждем или прерываем проверку обновлений и переходим на экран приветствия:
В открывшемся окне выставляем фильтры и кликаем по Далее.
Чтобы сократить вывод и отсечь ненужную информацию, используем фильтры.
Для работы из командной строки или написания скриптов, можно использовать Powershell командлет Get-MessageTrackingLog. Примеры его использования лучше всего посмотреть в графической оболочке — при формировании запроса с фильтрами, система выводит аналогичную команду на Powershell.
Простой запрос для отображения входящих сообщений:
Get-MessageTrackingLog -EventID “RECEIVE” -Start “2017/10/20 13:27:00” -End “2017/10/31 13:37:00”
* данная команда выведен сообщения за период от Start до End.
Мы можем увидеть ПРЕДУПРЕЖДЕНИЕ: Доступно больше результатов, чем показано в настоящий момент. Для их просмотра увеличьте значение параметра ResultSize. Это означает, что выведены не все результаты. Чтобы получить все данные, добавляем в конце команды -ResultSize unlimited.
Получить количество входящих сообщений:
(Get-MessageTrackingLog -EventID “RECEIVE” -ResultSize unlimited).Count
Входящие сообщения, которые пришли через определенный коннектор:
Get-MessageTrackingLog -EventID “RECEIVE” -ResultSize unlimited | Where {$_.ConnectorId -eq “Интернет”}
Поиск входящего письма для определенного получателя за определенный период, где тема сообщения содержит слово «вопрос»:
Get-MessageTrackingLog -EventID “RECEIVE” -Start “2017/10/20 00:00:00” -End “2017/10/21 00:00:00” -Recipients “[email protected]” -MessageSubject “вопрос”
Список сообщений, с поиском отправителя по домену:
Get-MessageTrackingLog -EventID “RECEIVE” -Start “2017/10/20 00:00:00” -End “2017/10/21 00:00:00” -ResultSize unlimited | Where {$_.Sender -like “*@mail.ru”}
Количество отправленных писем:
(Get-MessageTrackingLog -EventID “SEND” -ResultSize unlimited).Count
Для просмотра количества оправленных сообщений наружу стоит указать ConnectorId, иначе, в статистику попадут служебные письма:
(Get-MessageTrackingLog -EventID “SEND” -ResultSize unlimited | Where {$_.ConnectorId -eq “Наружу”}).Count
Список отправленных писем за определенный период:
Get-MessageTrackingLog -EventID “SEND” -Start “2017/10/20 00:00:00” -End “2017/10/21 00:00:00” -ResultSize unlimited
Список сообщений от определенного отправителя:
Get-MessageTrackingLog -EventID “SEND” -Start “2017/10/20 00:00:00” -End “2017/10/21 00:00:00” -Sender “[email protected]”
Поиск сообщения, отправленного определенному получателю:
Get-MessageTrackingLog -EventID “SEND” -Start “2017/10/20 00:00:00” -End “2017/10/21 00:00:00” -Recipients “[email protected]”
Поиск письма, отправленного на определенный домен:
Get-MessageTrackingLog -EventID “SEND” -ResultSize unlimited | where {$_.Recipients -like “*@mail.ru”}
Список коннекторов, через которые проходят письма:
Get-MessageTrackingLog | Select ConnectorId -unique
Попробуем посмотреть, в какие часы приходит максимальное число писем:
$username = “admins24\login”$password = cat C:\Scripts\password.txt | convertto-securestring
$cred = new-object -typename System.Management.Automation.PSCredential -argumentlist $username, $password$session = New-PSSession -ConfigurationName Microsoft.Exchange -ConnectionUri http://exchange_server.admins24.local/powershell -Credential $credImport-PSSession $session
$hourStaticsArr = @{}
Get-MessageTrackingLog -EventID “RECEIVE” -ResultSize unlimited | Where {$_.ConnectorId -match “Интернет”} | ForEach-Object { $hour = $_.Timestamp.Hour $hourStaticsArr[$hour]++}
$hourStaticsArr
* в двух словах, сначала мы подключаемся к серверу Exchange (в качестве пароля используем строку из файла, который заранее создан командой read-host -assecurestring | convertfrom-securestring | out-file C:\Scripts\password.txt). Затем получаем статистику входящих сообщений, вытаскиваем для каждого дату и час. После увеличиваем на единицу значение массива, в качестве ключа которого используем время (часы).
На работу скрипта может уйти несколько минут. Пример ответа:
Name Value—- —–23 240322 210821 169920 155719 140718 142617 204216 257615 257414 236313 3036
Продолжая использовать данный сайт вы принимаете политику конфиденциальности и cookies