Mtee is a Win32 console application that sends any data it receives to stdout and to any number of files. Useful if you want to watch and record the output from a batch file or program. It can also prefix each line of output with a timestamp.
Mtee is a 45kb standalone executable. It does not create any temporary files or write to the registry. There is no installation procedure, just run it. To remove all traces of Mtee from your system, just delete it.
Mtee is simple to use and only has several options. To list them, type:-
mtee /?
MTEE [/A | /U] [/C] [/D] [/T] [/E] [[/+] file] [...] /A Convert output to ANSI. Default output is same as input. /C Continue if errors occur opening/writing to file (advanced users only). /D Prefix each line of output with local date in YYYY-MM-DD format. /T Prefix each line of output with local time in HH:MM:SS.MSS format. /U Convert output to UNICODE. Default output is same as input. /E Exit with exit code of piped process. /ET Calculate and display elapsed time. /CPU Calculate and display average CPU load during execution. /+ Append to existing file. If omitted, existing file is overwritten. file File to receive the output. File is overwritten if /+ not specified. ... Any number of additional files. Use /+ before each file to append. Example usage:- 1) script.cmd | mtee result.txt 2) ftp -n -s:ftp.scr | mtee local.log /+ \\server\logs$\remote.log 3) update.cmd 2>&1 | mtee/d/t/+ log.txt 1) Sends the output of script.cmd to the console and to result.log. If result.txt already exists, it will be overwritten. 2) Sends output of automated ftp session to the console and two log files, local.log is overwritten if it already exists, remote.log is appended to. 3) Redirects stdout and stderr from update.cmd to console and appends to log.txt. Each line is prefixed with local date and time.
View Mtee help screen:-
mtee/?
Send the output of script.cmd to the console and to RESULT.LOG. If RESULT.LOG already exists, it will be overwritten:-
script.cmd | mtee result.log
Send the output of the automated ftp session to the console and to two log files, LOCAL.LOG is overwritten if it already exists. REMOTE.LOG is appended to if it exists, otherwise it is created:-
ftp -n -s:ftp.scr | mtee local.log /+ \\server\logs\remote.log
Make two copies of LOG whilst viewing LOG on the screen. If NEW1 and NEW2 already exist, they are overwritten:-
mtee < log new1 new2
Redirect stdout and stderr from UPDATE.CMD to the console and appends to LOG.TXT. Each line is prefixed with local date and time:-
update.cmd 2>&1 | mtee/d/t/+ log.txt
Send the output from BACKUP.CMD to the console and two remote log files. If there is an error opening any of the log files (server offline for instance) MTEE will continue. If the destination files already exist, they are appended to:-
backup.cmd | mtee /c/+ \\svr1\log$\bu.log /+ \\svr2\logs$\bu.log
Make multiple carbon copies of patch.exe:-
type patch.exe|mtee \\pc1\c$\patch.exe \\pc2\c$\patch.exe \\pc3\c$\patch.exe
Make a unicode log of HFNETCHK:-
hfnetchk|mtee/u log
Display stdout on the console, and stderr on the console and also to a log file with each line of stderr prefixed with local date and time:-
batch.cmd 2>&1 1>&3 3>&1 |mtee/t/d log
How can I determine the exit code of the process piped into Mtee?
Update Mtee to at least version v2.21 and use the /E option.
The CPU load calculations are based in the information from the GetSystemTimes
Windows API.
For reference, please check: https://docs.microsoft.com/en-us/windows/desktop/api/processthreadsapi/nf-processthreadsapi-getsystemtimes
The algorithm works by reading the idle, kernel and user times of the system (the time the system spent executing in each of these modes). Then, we define load time as the kernel time plus the user time and total time as kernel time plus user time plus idle time. Finally, the cpu load is calculated as the quotient between load time and total time. The mindset here is that everything that is not idle means loading the CPU.
This is a rough estimate and subject to criticsm. I'm willing to listen and implement better approaches.
Revision | Date | Changes |
---|---|---|
2.6 | 2019-04-29 | Improved processes list detection; don't open process handle if not needed. |
2.5 | 2019-04-14 | Added /CPU option (calculate and display average CPU load). |
2.4 | 2018-08-16 | Fixed elapsed time display (added a newline at the end). |
2.3 | 2018-06-21 | Added /ET option (calculate and display elapsed time). |
2.21 | 2016-08-07 | Added /E option (exit with exit code of process piped into Mtee). Cleaned up code - Mtee compiles without errors or warnings using a default install of the CodeBlocks IDE. |
2.2 | 2016-06-10 | Credit to Jari Kulmala for implementing workaround to avoid possible bug in Windows 10 where program takes 30 seconds to exit. |
2.1 | 2013-03-01 | Mtee is now open source software released under the MIT License. Credit to Jari Kulmala for addressing the following:-
|
2.0 | 2003-08-27 | The following features are new to Mtee v2.0:-
|
Code and documentation copyright 2001-2016 Ritchie Lawrence. Code released under MIT License