我正在尝试建立一个Scala项目性功能障碍,因此我运行一个命令:
sbt clean test > log.log
这意味着 sbt 工具写入 Windows 控制台的任何消息都应写入“log.log”文件。但有时我会将堆栈跟踪写入控制台而不是文件:
C:\path>sbt clean test > log.log
java.lang.ExceptionInInitializerError
at scala.concurrent.impl.Future$PromiseCompletingRunnable.liftedTree1$1(Future.scala:24)
at scala.concurrent.impl.Future$PromiseCompletingRunnable.run(Future.scala:24)
at scala.concurrent.impl.ExecutionContextImpl$AdaptedForkJoinTask.exec(ExecutionContextImpl.scala:121)
at scala.concurrent.forkjoin.ForkJoinTask.doExec(ForkJoinTask.java:260)
at scala.concurrent.forkjoin.ForkJoinPool$WorkQueue.runTask(ForkJoinPool.java:1339)
at scala.concurrent.forkjoin.ForkJoinPool.runWorker(ForkJoinPool.java:1979)
at scala.concurrent.forkjoin.ForkJoinWorkerThread.run(ForkJoinWorkerThread.java:107)
Caused by: java.lang.ClassCastException: Class org.infinispan.configuration.parsing.Parser60 does not implement org.infinispan.configuration.parsing.ConfigurationParser
为什么不将所有消息重定向到文件?
答案1
您粘贴的不是命令标准输出(STDOUT),而是命令的错误输出(STDERR)。
当您将“> output_file”添加到命令时,您仅将 STDOUT 重定向到该文件,而不是 STDERR。
如果要将错误输出到与标准输出相同的文件,则需要使用
sbt clean test > log.log 2>&1
“2>&1”的作用是将错误输出到与标准输出结果相同的位置。
您还可以做这样的事情:
sbt clean test > log.log 2>error.log
如果您想将它们分开,它将把 STDOUT 输出到 log.log,并将 STDERR 输出到名为 error.log 的第二个文件。
请参阅有关命令重定向器操作符的