81 lines
2.9 KiB
Go
81 lines
2.9 KiB
Go
package main
|
|
|
|
//import "time"
|
|
import "os"
|
|
import "github.com/romana/rlog"
|
|
|
|
func someRecursiveFunction(x int) {
|
|
// The Trace log functions allow you to set a log level with a numeric
|
|
// level, which could be determined at run time. Here, we are tracing or
|
|
// logging the first few levels of the recursive function (to whatever
|
|
// levels was determined via the RLOG_TRACE_LEVEL variable), but after that
|
|
// will stop logging, even though the function itself may decend further.
|
|
rlog.Tracef(x, "We're %d levels down now...", x)
|
|
if x < 10 {
|
|
someRecursiveFunction(x + 1)
|
|
} else {
|
|
rlog.Infof("Reached end of recursion at level %d", x)
|
|
}
|
|
}
|
|
|
|
func main() {
|
|
// Show different log levels
|
|
rlog.Info("Start of program")
|
|
rlog.Info("rlog is controlled via environment variables.")
|
|
rlog.Info("Try the following settings:")
|
|
rlog.Info(" export RLOG_LOG_LEVEL=DEBUG")
|
|
rlog.Info(" export RLOG_TRACE_LEVEL=5")
|
|
rlog.Info(" export RLOG_CALLER_INFO=yes")
|
|
rlog.Debug("You only see this if you did 'export RLOG_LOG_LEVEL=DEBUG'")
|
|
rlog.Infof("Format %s are possible %d", "strings", 123)
|
|
rlog.Warn("Warning level log message")
|
|
rlog.Error("Error level log message")
|
|
rlog.Critical("Critical level log message")
|
|
|
|
// Example of how to change settings programmatically from within
|
|
// the running program: Modify your own environment variables.
|
|
// Note that if the config file specifies the value with a '!' then
|
|
// this value cannot be changed by modifying the environment variable.
|
|
rlog.Debug("You can't see this if the log level is higher than DEBUG.")
|
|
os.Setenv("RLOG_LOG_LEVEL", "DEBUG")
|
|
rlog.UpdateEnv()
|
|
rlog.Debug("You can see this message, because we changed level to DEBUG.")
|
|
|
|
// Example of selective trace logging
|
|
rlog.Trace(1, "Trace messages have their own numeric levels")
|
|
rlog.Trace(1, "To see them set RLOG_TRACE_LEVEL to the cut-off number")
|
|
someRecursiveFunction(1)
|
|
|
|
// Example of redirecting log output to a new file at runtime
|
|
newLogFile, err := os.OpenFile("/tmp/rlog-output.log", os.O_APPEND|os.O_WRONLY|os.O_CREATE, 0777)
|
|
if err == nil {
|
|
rlog.Info("About to change log output. Check /tmp/rlog-output.log...")
|
|
rlog.SetOutput(newLogFile)
|
|
rlog.Info("This should go to the new logfile")
|
|
}
|
|
|
|
// Now redirecting it back to stderr. Any additional file logging will be
|
|
// closed with this call.
|
|
rlog.SetOutput(os.Stderr)
|
|
|
|
rlog.Info("Back to stderr")
|
|
|
|
// To test out changing the log configuration of a running process, set the
|
|
// RLOG_CONF_FILE environment variable to an absolute path for a
|
|
// configuration file that you can create and edit. Also, you might want to
|
|
// set RLOG_CONF_CHECK_INTERVAL to a smaller number, so you don't have to
|
|
// wait 15 seconds every time you change a setting.
|
|
// Then uncomment the loop below (and the 'time' import at the top) and run
|
|
// the example program.
|
|
|
|
/*
|
|
rlog.SetConfFile("some-other-rlog.conf")
|
|
|
|
for {
|
|
time.Sleep(time.Second * 1)
|
|
rlog.Debug("A debug log message")
|
|
rlog.Info("An info log message")
|
|
}
|
|
*/
|
|
}
|