您好,登錄后才能下訂單哦!
這篇文章將為大家詳細講解有關BAT批處理如何判斷服務是否正常運行,小編覺得挺實用的,因此分享給大家做個參考,希望大家閱讀完這篇文章后可以有所收獲。
先給大家普及下批處理的基本概念
批處理(Batch),也稱為批處理腳本。顧名思義,批處理就是對某對象進行批量的處理,通常被認為是一種簡化的腳本語言,它應用于DOS和Windows系統中。批處理文件的擴展名為bat 或cmd。目前比較常見的批處理包含兩類:DOS批處理和PS批處理。PS批處理是基于強大的圖片編輯軟件Photoshop的,用來批量處理圖片的腳本;而DOS批處理則是基于DOS命令的,用來自動地批量地執行DOS命令以實現特定操作的腳本。更復雜的情況,需要使用if、for、goto等命令控制程式的運行過程,如同C、Basic等高級語言一樣。如果需要實現更復雜的應用,利用外部程式是必要的,這包括系統本身提供的外部命令和第三方提供的工具或者軟件。批處理程序雖然是在命令行環境中運行,但不僅僅能使用命令行軟件,任何當前系統下可運行的程序都可以放在批處理文件中運行。
前言
某qlik sense服務器需要一個health check(健康狀態監測)的程序,所以就有了一下的批處理腳本。
大致功能如下:
批處理獲取當前日期時間
批處理生成動態的文件名
批處理輸出echo到日志文件
批處理遍歷列表list
批處理函數與call函數
判斷服務是否運行中
批處理count計數
批處理copy復制文件
批處理判斷大于gtr(記住那輛跑車名,批處理大于、小于、等于、不小于、不大于和不等于)
@echo off color 2E set YYYYmmdd=%date:~0,4%%date:~5,2%%date:~8,2% set hhmiss=%time:~0,2%%time:~3,2%%time:~6,2% set filename=healthcheck.log REM set "filename=healthcheck_%YYYYmmdd%_%hhmiss%.log" set "datetime=%YYYYmmdd%%hhmiss%" set allCount=0 set errorCount=0 set checkList="QlikSenseServiceDispatcher" "QlikSenseSchedulerService" "QlikSenseRepositoryService" "QlikSenseRepositoryDatabase" "QlikSenseProxyService" "QlikSensePrintingService" "QlikSenseEngineService" "QlikLoggingService" echo ============================================ >%filename% echo Health Checking by Qlik Team >>%filename% echo zhengkai.blog.csdn.net echo (datetime: %datetime% ) >>%filename% echo ============================================ >>%filename% echo. >>%filename% echo. >>%filename% for %%L in (%checkList%) do call :health_check %%L echo ============================================ >>%filename% echo Checking Finish. >>%filename% echo. >>%filename% echo Error : %errorCount% of %allCount% >>%filename% echo. >>%filename% echo ============================================ >>%filename% call :check_status echo ============================================ >>%filename% goto:end :health_check sc query |find /i %1 >nul 2>nul if not errorlevel 1 ( echo SUCCESS...... %1 >>%filename% )else ( echo FAILD...... %1 is error ! >>%filename% set /a errorCount+=1 ) set /a allCount+=1 goto:eof :check_status if %errorCount% gtr 0 ( echo ###### this server is Not Health >>%filename% ) else ( echo ###### this server is Health >>%filename% ) goto:eof :end copy %filename% \\xxxx\DataShare\CSDN\ZhengKai\
批處理獲取當前日期時間,生成動態的文件名
set YYYYmmdd=%date:~0,4%%date:~5,2%%date:~8,2% set hhmiss=%time:~0,2%%time:~3,2%%time:~6,2% set "filename=healthcheck_%YYYYmmdd%_%hhmiss%.log" echo %filename%
批處理輸出echo到日志文件
> 就是清空輸出文件,重新輸出層
>> 就是追加到日子和文件
echo ============================================ >%filename% echo Health Checking by Qlik Team >>%filename% echo ============================================ >>%filename%
批處理遍歷列表list
定義在一個List會后,就可以開始使用
for %%L 用什么變量來遍歷
in (%checkList%) 遍歷哪個數組
do echo %%L 遍歷來做什么
set checkList="QlikSenseServiceDispatcher" "QlikSenseSchedulerService" "QlikSenseRepositoryService" "QlikSenseRepositoryDatabase" "QlikSenseProxyService" "QlikSensePrintingService" "QlikSenseEngineService" "QlikLoggingService" echo ============================================ >%filename% echo Health Checking List >>%filename% for %%L in (%checkList%) do echo %%L echo ============================================ >>%filename%
批處理函數與call函數
定義一個:function_name,中間是函數內容,后面以goto:eof結尾
call :check_status :check_status if %errorCount% gtr 0 ( echo ###### this server is Not Health >>%filename% ) else ( echo ###### this server is Health >>%filename% ) goto:eof
批處理count計數
計數加一 set /a allCount+=1
set allCount=0 for %%L in (%checkList%) do set /a allCount+=1
批處理copy復制文件
復制文件 copy 文件名 目錄頁
復制文件夾用xcopy,指定的目錄連文件和目錄結構一并拷貝
copy %filename% "\\xxxx\DataShare\CSDN\ZhengKai\"
批處理大于、小于、等于、不小于、不大于和不等于
EQU - 等于
NEQ - 不等于
LSS - 小于
LEQ - 小于或等于
GTR - 大于
GEQ - 大于或等于
if %errorCount% gtr 0 ( echo ###### this server is Not Health >>%filename% ) else ( echo ###### this server is Health >>%filename% )
關于“BAT批處理如何判斷服務是否正常運行”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,使各位可以學到更多知識,如果覺得文章不錯,請把它分享出去讓更多的人看到。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。