windows下bat批處理實現守護進程(有日志)


開發部的一個核心程序總是會自己宕機,然后需要手工去起,而這個服務的安全級別又很高,只有我可以操作,搞得我晚上老沒法睡,昨晚實在受不了了,想起以前在hp-ux下寫的shell守護進程,這回搞個windows下的bat版守護程序吧,當時晚上思路已經很遲鈍了,就叫了個兄弟讓他寫了,上去后運行效果不錯,至少昨晚我安心睡了7小時。

早上來把程序改完善一些,增加了記錄等功能。
實現:

檢查是否有notepad,要用的話就算成自己的進程名,如果進程宕了就過會自動重啟(會在當前目錄下生成一個start.bat)

@echo off

set _task=notepad.exe
set _svr=c:/windows/notepad.exe
set _des=start.bat

:checkstart
for /f "tokens=5" %%n in ('qprocess.exe ^| find "%_task%" ') do (
if %%n==%_task% (goto checkag) else goto startsvr
)

:startsvr
echo %time%
echo ********程序開始啟動********
echo 程序重新啟動於 %time% ,請檢查系統日志 >> restart_service.txt
echo start %_svr% > %_des%
echo exit >> %_des%
start %_des%
set/p=.<nul
for /L %%i in (1 1 10) do set /p a=.<nul&ping.exe /n 2 127.0.0.1>nul
echo .
echo Wscript.Sleep WScript.Arguments(0) >%tmp%/delay.vbs
cscript //b //nologo %tmp%/delay.vbs 10000
del %_des% /Q
echo ********程序啟動完成********
goto checkstart


:checkag
echo %time% 程序運行正常,10秒后繼續檢查..
echo Wscript.Sleep WScript.Arguments(0) >%tmp%/delay.vbs
cscript //b //nologo %tmp%/delay.vbs 10000
goto checkstart

 

 

出處:https://blog.csdn.net/jiangxinyu/article/details/5217342

========================================================================

 

這個腳本提供兩種方式守護,一種是通過進程名,但對於進程名都是java.exe的java程序不適用,另一種是通過netstat查找應用程序所監聽的端口是否正在被監聽。這兩種方式可以在腳本中通過兩個冒號注釋來選擇切換。下面是設置成通過端口來守護的,當端口沒被監聽則打開一個zip文件,所以運行后會發現沒過5秒會重復打開這個zip文件,除非這個zip文件打開后會自動監聽8080端口,那當然是不可能的!腳本涉及的命令就不解釋了搜一下就知道了。
@echo off

::檢測時間間隔,單位:秒
set _interval=5

::需要守護的進程名稱
set _processName=WinRAR

::需要守護的進程啟動命令
set _processCmd=C:\ideavim-0.32.zip

::需要守護的進程預估啟動完畢所需時間,單位:秒
set _processTimeout=10

::需要守護的進程所監聽的端口
set _port=8080

::進程用戶名,一般是Administrator
set _username=Administrator 

:LOOP
set /a isAlive=false

::通過進程名稱檢測
::tasklist /FI "username eq %_username%" | find /C "%_processName%" > temp.txt
::set /p num= < temp.txt
::del /F temp.txt

::通過進程的端口是否正在被監聽檢測
netstat -an | find /C "0.0.0.0:%_port%" > temp.txt
set /p num= < temp.txt
del /F temp.txt

if "%num%" == "0" (
start %_processCmd% | echo 啟動 %_processName% 於 %time%
choice /D y /t %_processTimeout% > nul
)

if "%num%" NEQ "0" echo 已啟動

::ping -n %_interval% 127.1>nul
choice /D y /t %_interval% >nul

goto LOOP

該腳本運行后會出現一個dos窗口,若覺得礙眼可以用記事本將下面保存為擴展名為.vbs的文件。其中guard.bat是上面批處理保存的文件名。兩個文件放在同一目錄下雙擊vbs文件后,守護進程就在后台運行了,單這樣得通過資源管理器結束cmd進程才能停止守護進程。

set ws=WScript.CreateObject("WScript.Shell")
ws.Run "guard.bat",0
 

 

出處:https://blog.csdn.net/qin9r3y/article/details/22805095

==================================================================

根據上面的內容自己修改一個放到項目上使用:

1)可以根據參數,執行指定的程序

2)可以保存詳細的執行日志

 

版本一:

@echo off
title processWatch
cls
set d=%date:~0,10%
set d=%d: =0%
echo %d%
set logFile=.\processWatch_%d:-=%.txt
echo 現在時間:%date%%time% 
echo ********程序開始啟動******** >> %logFile%

set runAppPath=%1
set runAppPath="C:\Users\Administrator\Desktop\新建文件夾\Cares.AutoUpdate.exe"
set runAppFolder=''
if '%runAppPath%'=='' (goto end)

set _processName=''
set _processNameExt=''
::檢測時間間隔,單位:秒
set _interval=10

for %%a in (%runAppPath%) do (
set _processName=%%~na
set _processNameExt=%%~nxa
set runAppFolder=%%~dpa
)
goto checkstart

rem 以下是測試代碼
echo %_processName%
echo %_processNameExt%
echo %runAppFolder%
echo %runAppPath%
echo ====================================================
goto end


:checkstart
set d=%date:~0,10%
set d=%d: =0%
set logFile=.\processWatch_%d:-=%.txt
for /f "tokens=1" %%n in ('tasklist.exe ^| find /I "%_processNameExt%" ') do ( 
if '%%n'=='%_processNameExt%' (echo 檢查進程【%_processNameExt%】正在運行 >> %logFile% && goto checkend) )
echo 檢查進程【%_processNameExt%】未在運行 >> %logFile%

:startApp
echo, && echo ********開始啟動程序********
echo ********開始啟動程序******** >> %logFile%
echo [%date:~0,10%%time:~0,8%] 未檢測到【%_processNameExt%】的進程,將重新啟動程序 >> %logFile%
echo [%date:~0,10%%time:~0,8%] 重新啟動程序:%runAppPath%
echo [%date:~0,10%%time:~0,8%] 重新啟動程序:%runAppPath% >> %logFile%
echo 開始執行 start "" %runAppPath% >> %logFile%
pushd %runAppFolder%
start "" %runAppPath%
popd
echo ********啟動程序完成******** && echo,
echo ********啟動程序完成******** >> %logFile%
echo, >> %logFile%


:checkend
echo [%date:~0,10%%time:~0,8%] 程序【%_processNameExt%】運行正常,%_interval%秒后繼續檢查......
choice /t %_interval% /d y /n >nul
goto checkstart

:end
echo end.
View Code

 

后續將繼續優化


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM