Powershell小技巧之從文件獲取系統(tǒng)日志
更新時間:2014年10月24日 09:21:02 投稿:hebedich
事件日志對于系統(tǒng)管理員的重要性自不待言,而基于圖形界面的事件查看器毫無疑問是我們進行日志管理的首選工具,但絕不是最快捷的工具。其實,PowerShell提供了一種更簡單的方式,利用它我們不僅可訪問當前系統(tǒng)的事件日志,而且還可對數(shù)據(jù)進行排序、格式化等等。
有時你可能會需要分析系統(tǒng)文件將他們傳輸?shù)接脖P,或你想直接從“evtx”讀取系統(tǒng)日志。
你可以這樣做:
復制代碼 代碼如下:
$path = "$env:windir\System32\Winevt\Logs\Setup.evtx"
Get-WinEvent -Path $path
另附上一段獲取系統(tǒng)日志的代碼
復制代碼 代碼如下:
$StartTime = (get-date).Date + (new-timespan -Hours 6 -Minutes 35)
$EndTime = (get-date).Date + (new-timespan -Hours 6 -Minutes 36)
$global:TaskStart
$Global:TaskComplete
$Global:events
$Global:event
$Global:TimeSpent
$Global:events = get-winevent -FilterHashtable @{logname = "Microsoft-Windows-TaskScheduler/Operational"; ID=107;StartTime=$StartTime;EndTime=$EndTime}
Foreach($Global:event in $Global:events)
{
cls
$StartLogs=get-winevent -FilterHashtable @{logname = "Microsoft-Windows-TaskScheduler/Operational";ID=100;StartTime=$StartTime}
$CompleteLogs=get-winevent -FilterHashtable @{logname = "Microsoft-Windows-TaskScheduler/Operational";id=102;StartTime=$StartTime}
$global:TaskStart=$StartLogs | where {$_.ActivityId -eq $Global:event.ActivityId}
$Global:TaskComplete=$CompleteLogs | where {$_.ActivityId -eq $Global:event.ActivityId}
$global:TimeSpent=($global:TaskComplete.timeCreated-$global:TaskStart.timeCreated).TotaLMinutes
if(($global:TaskStart -ne $NULL) -and ($Global:TaskComplete -ne $null) -and ($Global:TimeSpent -gt 1)){
$Messagebody="Sync task started at: "+$global:TaskStart.TimeCreated.DateTime+"`r`n"
$Messagebody=$Messagebody+"`r`nSync task completed at: "+$global:TaskComplete.timeCreated.DateTime+"`r`n"
$Messagebody=$Messagebody+"`r`nTask lasted for "+("{0:N2}" -f ($Global:TimeSpent) )+" minutes"
Send-MailMessage -From "CustomerLog@avepoint.com" -To "Zhijie.bai@avepoint.com","Infrastructure_cn@avepoint.com" -Subject "Customer Logs Sync Report:Success" -Body $Messagebody -SmtpServer "10.100.100.153" -Encoding UTF8
}
else{
$Messagebody="########################################################################`r`n"
$Messagebody=$Messagebody+"`r`nCustom logs Sync failed, please login 10.2.0.125 to check and sync again`r`n"
$Messagebody=$Messagebody+"`r`n########################################################################`r`n"
Send-MailMessage -From "CustomerLog@avepoint.com" -To "Zhijie.bai@avepoint.com","Infrastructure_cn@avepoint.com" -Subject "Customer Logs Sync Report:Failed" -Body $Messagebody -SmtpServer "10.100.100.153" -Encoding UTF8 -Priority High
}
}
支持Powershell所有版本
相關文章
PowerShell中使用ArrayList實現(xiàn)數(shù)組插入、刪除、添加例子
這篇文章主要介紹了PowerShell中使用ArrayList實現(xiàn)數(shù)組插入、刪除、添加例子,使用ArrayList效率更高、也更方便,需要的朋友可以參考下2014-08-08Powershell改變腳本執(zhí)行優(yōu)先權的代碼分享
這篇文章主要介紹了Powershell改變腳本執(zhí)行優(yōu)先權的代碼分享,本文通過控制進程的方式調整程序的執(zhí)行順序,需要的朋友可以參考下2014-11-11PowerShell中調用.NET對象的靜態(tài)方法、靜態(tài)屬性和類方法、類屬性例子
這篇文章主要介紹了PowerShell中調用.NET對象的靜態(tài)方法、靜態(tài)屬性和類方法、類屬性例子,即PowerShell中如何使用.NET對象的一些方法,需要的朋友可以參考下2014-08-08PowerShell計算腳本執(zhí)行時間的實現(xiàn)方法
如果你想知道一個腳本運行了多久時間,你可以使用Measure-Command,但是這個命令僅用于診斷目的且沒有輸出2014-04-04PowerShell中使用PrintManagement管理打印機示例
這篇文章主要介紹了PowerShell中使用PrintManagement管理打印機示例,本文給出了一個安裝打印機驅動和打印機端口的例子,需要的朋友可以參考下2015-03-03PowerShell中使用Out-String命令把對象轉換成字符串輸出的例子
這篇文章主要介紹了PowerShell中使用Out-String命令把對象轉換成字符串輸出的例子,即把對象轉為字符串的方法,需要的朋友可以參考下2014-08-08