Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/liurui-software/mmlog
Log rotation tool for shell scripts, or any apps which generate logs to standard output or standard error. (Note this is a different project from the joyent/mmlog which is a tool for dumping chat history from a Mattermost chat server.)
https://github.com/liurui-software/mmlog
log-rotation logging tomcat-log
Last synced: 8 days ago
JSON representation
Log rotation tool for shell scripts, or any apps which generate logs to standard output or standard error. (Note this is a different project from the joyent/mmlog which is a tool for dumping chat history from a Mattermost chat server.)
- Host: GitHub
- URL: https://github.com/liurui-software/mmlog
- Owner: liurui-software
- License: apache-2.0
- Created: 2019-09-09T01:16:40.000Z (over 5 years ago)
- Default Branch: master
- Last Pushed: 2024-08-07T07:51:51.000Z (5 months ago)
- Last Synced: 2024-12-19T16:32:13.084Z (21 days ago)
- Topics: log-rotation, logging, tomcat-log
- Language: Makefile
- Homepage:
- Size: 111 KB
- Stars: 10
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# mmlog
"mmlog" is a simple log rotation tool for shell scripts, or apps which generate logging data to standard output or standard error. "mmlog" is an useful tool to prevent logging data to saturates user's disk.
There is built-in tool named "logrotate" in some systems. But "logrotate" costs too much CPU and cannot control the maximum size of the log file. "mmlog" is much more lightweight, esier configuration, and with more good features for shell scripts, or apps which generate logging data to standard output or standard error.
## Build mmlog for your system
"mmlog" binaries for 7 platforms are provided in the "build" folder. You can also build "mmlog" for your own platforms with following command:
```
make
```## Syntax to use mmlog:
```
| mmlog
Or:
mmlog
```## Environment Varibles:
```
MM_LOGFILE_NUM: Number of log files to rotate. Default is 10.
MM_LOGFILE: Name of the log file. Default is "mmlog"
MM_LOGSIZE: Max size of one log file. Default is 10M.
```## Samples of usage
1) Rotate logging data from standard output and error, set logfile name and size to rotate, run in background...
```
export MM_LOGFILE=myapp
export MM_LOGSIZE=1000000
nohup ./myapp 2>&1 | ./mmlog &
```2) Rotate your Tomcat log
For example your Tomcat installed on Linux/x64 and is located in directory "TOMCAT_HOME=/opt/apache-tomcat-9.0.44".
Down `mmlog` for Linux from page: https://github.com/liurui-1/mmlog/blob/master/build/linux.amd64/mmlog and copy to directory "$TOMCAT_HOME/bin". Use following command to start Tomcat. Then you make your Tomcat log rotated. The major Tomcat log file originally named `catalina.out` which can grow up to unlimited size,is now named tomcat#.log as 10 rotated log files up to 1M size).
```
export TOMCAT_HOME=/opt/apache-tomcat-9.0.44
export CATALINA_OUT_CMD="nohup $TOMCAT_HOME/bin/mmlog"
export MM_LOGFILE=$TOMCAT_HOME/logs/tomcat
export MM_LOGSIZE=1000000
$TOMCAT_HOME/bin/startup.sh
```