 Documentation
      ¶
      Documentation
      ¶
    
    
  
    
  
    Index ¶
- Constants
- func Close()
- func Critical(skip int, format string, v ...interface{})
- func Debug(format string, v ...interface{})
- func Error(skip int, format string, v ...interface{})
- func Fatal(skip int, format string, v ...interface{})
- func Info(format string, v ...interface{})
- func NewGitLogger(logPath string)
- func NewLogger(bufLen int64, mode, config string)
- func Register(name string, log loggerType)
- func Trace(format string, v ...interface{})
- func Warn(format string, v ...interface{})
- type Brush
- type ConnWriter
- type ConsoleWriter
- type FileLogWriter
- type Logger
- func (l *Logger) Close()
- func (l *Logger) Critical(skip int, format string, v ...interface{})
- func (l *Logger) Debug(format string, v ...interface{})
- func (l *Logger) DelLogger(adapter string) error
- func (l *Logger) Error(skip int, format string, v ...interface{})
- func (l *Logger) Fatal(skip int, format string, v ...interface{})
- func (l *Logger) Flush()
- func (l *Logger) Info(format string, v ...interface{})
- func (l *Logger) SetLogger(adapter string, config string) error
- func (l *Logger) StartLogger()
- func (l *Logger) Trace(format string, v ...interface{})
- func (l *Logger) Warn(format string, v ...interface{})
 
- type LoggerInterface
- type MuxWriter
- type SMTPWriter
Constants ¶
const ( TRACE = iota DEBUG INFO WARN ERROR CRITICAL FATAL )
log levels
Variables ¶
This section is empty.
Functions ¶
func NewGitLogger ¶
func NewGitLogger(logPath string)
NewGitLogger create a logger for git FIXME: use same log level as other loggers.
Types ¶
type ConnWriter ¶
type ConnWriter struct {
	ReconnectOnMsg bool   `json:"reconnectOnMsg"`
	Reconnect      bool   `json:"reconnect"`
	Net            string `json:"net"`
	Addr           string `json:"addr"`
	Level          int    `json:"level"`
	// contains filtered or unexported fields
}
    ConnWriter implements LoggerInterface. it writes messages in keep-live tcp connection.
func (*ConnWriter) Destroy ¶
func (cw *ConnWriter) Destroy()
Destroy destroy connection writer and close tcp listener.
func (*ConnWriter) Init ¶
func (cw *ConnWriter) Init(jsonconfig string) error
Init inits connection writer with json config. json config only need key "level".
type ConsoleWriter ¶
type ConsoleWriter struct {
	Level int `json:"level"`
	// contains filtered or unexported fields
}
    ConsoleWriter implements LoggerInterface and writes messages to terminal.
func (*ConsoleWriter) Init ¶
func (cw *ConsoleWriter) Init(config string) error
Init inits connection writer with json config. json config only need key "level".
type FileLogWriter ¶
type FileLogWriter struct {
	*log.Logger
	// The opened file
	Filename string `json:"filename"`
	Maxlines int `json:"maxlines"`
	// Rotate at size
	Maxsize int `json:"maxsize"`
	// Rotate daily
	Daily   bool  `json:"daily"`
	Maxdays int64 `json:"maxdays"`
	Rotate bool `json:"rotate"`
	Level int `json:"level"`
	// contains filtered or unexported fields
}
    FileLogWriter implements LoggerInterface. It writes messages by lines limit, file size limit, or time frequency.
func (*FileLogWriter) Destroy ¶
func (w *FileLogWriter) Destroy()
Destroy destroy file logger, close file writer.
func (*FileLogWriter) DoRotate ¶
func (w *FileLogWriter) DoRotate() error
DoRotate means it need to write file in new file. new file name like xx.log.2013-01-01.2
func (*FileLogWriter) Flush ¶
func (w *FileLogWriter) Flush()
Flush flush file logger. there are no buffering messages in file logger in memory. flush file means sync file from disk.
func (*FileLogWriter) Init ¶
func (w *FileLogWriter) Init(config string) error
Init file logger with json config. config like:
{
"filename":"log/gogs.log",
"maxlines":10000,
"maxsize":1<<30,
"daily":true,
"maxdays":15,
"rotate":true
}
  
  func (*FileLogWriter) StartLogger ¶
func (w *FileLogWriter) StartLogger() error
StartLogger start file logger. create log file and set to locker-inside file writer.
type Logger ¶
type Logger struct {
	// contains filtered or unexported fields
}
    Logger is default logger in beego application. it can contain several providers and log message into all providers.
var ( // GitLogger logger for git GitLogger *Logger )
func (*Logger) Close ¶
func (l *Logger) Close()
Close closes logger, flush all chan data and destroy all adapter instances.
type LoggerInterface ¶
type LoggerInterface interface {
	Init(config string) error
	WriteMsg(msg string, skip, level int) error
	Destroy()
	Flush()
}
    LoggerInterface represents behaviors of a logger provider.
func NewConn ¶
func NewConn() LoggerInterface
NewConn creates new ConnWrite returning as LoggerInterface.
func NewConsole ¶
func NewConsole() LoggerInterface
NewConsole create ConsoleWriter returning as LoggerInterface.
func NewFileWriter ¶
func NewFileWriter() LoggerInterface
NewFileWriter create a FileLogWriter returning as LoggerInterface.
func NewSMTPWriter ¶ added in v1.0.0
func NewSMTPWriter() LoggerInterface
NewSMTPWriter creates smtp writer.
type SMTPWriter ¶ added in v1.0.0
type SMTPWriter struct {
	Username           string   `json:"Username"`
	Password           string   `json:"password"`
	Host               string   `json:"Host"`
	Subject            string   `json:"subject"`
	RecipientAddresses []string `json:"sendTos"`
	Level              int      `json:"level"`
}
    SMTPWriter implements LoggerInterface and is used to send emails via given SMTP-server.
func (*SMTPWriter) Destroy ¶ added in v1.0.0
func (sw *SMTPWriter) Destroy()
Destroy when writer is destroy
func (*SMTPWriter) Flush ¶ added in v1.0.0
func (sw *SMTPWriter) Flush()
Flush when log should be flushed
func (*SMTPWriter) Init ¶ added in v1.0.0
func (sw *SMTPWriter) Init(jsonconfig string) error
Init smtp writer with json config. config like:
{
	"Username":"example@gmail.com",
	"password:"password",
	"host":"smtp.gmail.com:465",
	"subject":"email title",
	"sendTos":["email1","email2"],
	"level":LevelError
}