先给大家普及下批处理的基本概念
批处理(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批处理判断服务是否正常运行的方法(批处理命令综合应用),希望对大家有所帮助,也非常感谢大家对网站的支持!
《魔兽世界》大逃杀!60人新游玩模式《强袭风暴》3月21日上线
暴雪近日发布了《魔兽世界》10.2.6 更新内容,新游玩模式《强袭风暴》即将于3月21 日在亚服上线,届时玩家将前往阿拉希高地展开一场 60 人大逃杀对战。
艾泽拉斯的冒险者已经征服了艾泽拉斯的大地及遥远的彼岸。他们在对抗世界上最致命的敌人时展现出过人的手腕,并且成功阻止终结宇宙等级的威胁。当他们在为即将于《魔兽世界》资料片《地心之战》中来袭的萨拉塔斯势力做战斗准备时,他们还需要在熟悉的阿拉希高地面对一个全新的敌人──那就是彼此。在《巨龙崛起》10.2.6 更新的《强袭风暴》中,玩家将会进入一个全新的海盗主题大逃杀式限时活动,其中包含极高的风险和史诗级的奖励。
《强袭风暴》不是普通的战场,作为一个独立于主游戏之外的活动,玩家可以用大逃杀的风格来体验《魔兽世界》,不分职业、不分装备(除了你在赛局中捡到的),光是技巧和战略的强弱之分就能决定出谁才是能坚持到最后的赢家。本次活动将会开放单人和双人模式,玩家在加入海盗主题的预赛大厅区域前,可以从强袭风暴角色画面新增好友。游玩游戏将可以累计名望轨迹,《巨龙崛起》和《魔兽世界:巫妖王之怒 经典版》的玩家都可以获得奖励。
更新日志
- 小骆驼-《草原狼2(蓝光CD)》[原抓WAV+CUE]
- 群星《欢迎来到我身边 电影原声专辑》[320K/MP3][105.02MB]
- 群星《欢迎来到我身边 电影原声专辑》[FLAC/分轨][480.9MB]
- 雷婷《梦里蓝天HQⅡ》 2023头版限量编号低速原抓[WAV+CUE][463M]
- 群星《2024好听新歌42》AI调整音效【WAV分轨】
- 王思雨-《思念陪着鸿雁飞》WAV
- 王思雨《喜马拉雅HQ》头版限量编号[WAV+CUE]
- 李健《无时无刻》[WAV+CUE][590M]
- 陈奕迅《酝酿》[WAV分轨][502M]
- 卓依婷《化蝶》2CD[WAV+CUE][1.1G]
- 群星《吉他王(黑胶CD)》[WAV+CUE]
- 齐秦《穿乐(穿越)》[WAV+CUE]
- 发烧珍品《数位CD音响测试-动向效果(九)》【WAV+CUE】
- 邝美云《邝美云精装歌集》[DSF][1.6G]
- 吕方《爱一回伤一回》[WAV+CUE][454M]