batch-file - 如何在日志文件中打印命令行本身以进行日志跟踪?
问题描述
我有一个通过 .bat 文件调用的 java 代码。该批次工作正常。有没有办法可以将我正在执行的命令行打印到标准输出(日志)文件?
例如,我的命令是
call dpp.bat -r %BASE_URL% views -af xyz.csv >> creation.log 2>&1
在我的 bat 文件中,我有多个此类各种类型的命令。在执行这个单个批处理文件时,所有内容都会被一个接一个地执行,并且所有日志都被写入该单个文件 creation.log。并且用户迷失了查看日志,哪个命令行执行了什么!
有没有一种简单的方法,比如添加一些将命令行也打印到日志文件的行?
解决方案
如果我理解正确,您希望将命令回显和命令输出都写入日志文件。
为此,您可以执行以下操作:
- 将您要登录的代码放入子例程中,然后由
call
. - 仅将命令的输出重定向
call
到日志文件。 - 放入
@echo off
批处理文件的主要部分。 - 放入
@echo on
子程序。 - 不要忘记放置
exit /B
在主要部分的末尾。
这是一个例子:
@rem // Turn command echoes off in the main section:
@echo off
@rem // Redirect only the output of `call` to the log file:
call :SUB >> "creation.log" 2>&1
@rem // Terminate main section:
@exit /B
:SUB
@rem // Turn command echoes on in the sub-section:
@echo on
@rem /* Place all command lines you want to log here;
@rem ensure NOT to precede these lines with `@`: */
call dpp -r %BASE_URL% views -af xyz.csv
@rem // Terminate sub-section:
@exit /B
或者,您可以将每个命令放入一个只迭代一次的for
循环中:
@rem // Turn command echoes on:
@echo on
@rem // Place all command lines you want to log into `for` loops that iterate once:
@(for %%# in (.) do call dpp -r %BASE_URL% views -af xyz.csv) > "creation.log" 2>&1
@rem // Terminate script:
@exit /B
推荐阅读
- javascript - 如果从 API 获取数据,则 Vue.js 中的数组有时为空
- c# - 违反 PRIMARY KEY 约束。无法在对象中插入重复键
- jenkins - 执行 Jenkinsfile 时如何获取管道配置字段“脚本路径”?
- ios - 如何在路径内部描边 uibezierpath 的边界?
- c# - SQL server - 在插入之前屏蔽/更改值唯一标识符
- html - 从primeng以角度实现日历时出错
- puppet - 测试木偶中未定义的事实
- python - 带有硒测试的 Django 频道 2 失败
- html - Bootstrap nav-justified 不占用全宽
- go - Windows 如何为 Golang 制作