我是蝙蝠脚本的新手。我想在下面的脚本中检查Web是否已启动,如果没有重新启动coldfusion并将所有信息保存到日志文件中。
@REM Remove any existing files.
del C:\Users\Administrator\check.txt
@REM to download file
wget -O check.txt --no-check-certificate https://10.2.3.30/ebanking/ch/en-en/index.cfm
@REM Search for the term in the previously downloaded file.
FINDSTR /C:"index.cfm" check.txt
if errorlevel equ 1 notfound
found
cls
:notfound
echo notfound > log.txt
echo stopping ebanking >> log.txt
call C:\ColdFusion10\cfusion\bin\cfstop.bat
echo starting ebanking >> log.txt
call C:\ColdFusion10\cfusion\bin\cfstart.bat
cls
exit
:found
echo found >> log.txt
cls
exit
答案 0 :(得分:0)
您错过了goto
标签notfound
。对于逻辑,我在notfound / found
@echo off
pushd "C:\Users\Administrator"
@REM Remove any existing files.
del check.txt
@REM to download file
wget -O check.txt --no-check-certificate https://10.2.3.30/ebanking/ch/en-en/index.cfm
@REM Search for the term in the previously downloaded file.
FINDSTR /C:"index.cfm" check.txt
if errorlevel equ 1 (goto notfound)
:found
echo found >> log.txt
exit /b 0
:notfound
echo notfound > log.txt
echo stopping ebanking >> log.txt
call C:\ColdFusion10\cfusion\bin\cfstop.bat
echo starting ebanking >> log.txt
call C:\ColdFusion10\cfusion\bin\cfstart.bat
exit
您可以在循环中将代码简化为以下内容
@echo off
set "someurl=https://10.2.3.30/ebanking/ch/en-en/index.cfm"
:loop
wget --server-response -nv --spider %someurl% 2>&1 | find "HTTP/1.1 200 OK">nul
if errorlevel 1 (
echo %DATE% %TIME%: stopping ebanking>> log.txt
call C:\ColdFusion10\cfusion\bin\cfstop.bat
timeout 5>nul
echo %DATE% %TIME%: starting ebanking>> log.txt
call C:\ColdFusion10\cfusion\bin\cfstart.bat
) else (
echo %DATE% %TIME%: site is up>> log.txt
)
rem Wait 1 hour before loop
timeout 3600
goto loop