// Copyright 2014 The Gogs Authors. All rights reserved. // Use of this source code is governed by a MIT-style // license that can be found in the LICENSE file. package log import ( "encoding/json" "github.com/go-xorm/xorm" ) type Log struct { Id int64 Level int Msg string `xorm:"TEXT"` } // DatabaseWriter implements LoggerInterface and is used to log into database. type DatabaseWriter struct { Driver string `json:"driver"` Conn string `json:"conn"` Level int `json:"level"` x *xorm.Engine } func NewDatabase() LoggerInterface { return &DatabaseWriter{Level: TRACE} } // init database writer with json config. // config like: // { // "driver": "mysql" // "conn":"root:root@tcp(127.0.0.1:3306)/gogs?charset=utf8", // "level": 0 // } // connection string is based on xorm. func (d *DatabaseWriter) Init(jsonconfig string) (err error) { if err = json.Unmarshal([]byte(jsonconfig), d); err != nil { return err } d.x, err = xorm.NewEngine(d.Driver, d.Conn) if err != nil { return err } return d.x.Sync(new(Log)) } // write message in database writer. func (d *DatabaseWriter) WriteMsg(msg string, skip, level int) error { if level < d.Level { return nil } _, err := d.x.Insert(&Log{Level: level, Msg: msg}) return err } func (_ *DatabaseWriter) Flush() { } func (_ *DatabaseWriter) Destroy() { } func init() { Register("database", NewDatabase) }
session(release): write data/sessions/a/f/afb9c0bc2954090d: no space left on device
github.com/go-macaron/session@v0.0.0-20190805070824-1a3cdc6f5659/session.go:199 (0x8b2934) gopkg.in/macaron.v1@v1.3.9/context.go:79 (0x83d0a0) github.com/go-macaron/inject@v0.0.0-20160627170012-d8a0b8677191/inject.go:157 (0x80ab07) github.com/go-macaron/inject@v0.0.0-20160627170012-d8a0b8677191/inject.go:135 (0x80a8a8) gopkg.in/macaron.v1@v1.3.9/context.go:121 (0x83d1f8) gopkg.in/macaron.v1@v1.3.9/context.go:112 (0x84fdb5) gopkg.in/macaron.v1@v1.3.9/recovery.go:161 (0x84fda8) gopkg.in/macaron.v1@v1.3.9/logger.go:40 (0x840c73) github.com/go-macaron/inject@v0.0.0-20160627170012-d8a0b8677191/inject.go:157 (0x80ab07) github.com/go-macaron/inject@v0.0.0-20160627170012-d8a0b8677191/inject.go:135 (0x80a8a8) gopkg.in/macaron.v1@v1.3.9/context.go:121 (0x83d1f8) gopkg.in/macaron.v1@v1.3.9/router.go:187 (0x850fc6) gopkg.in/macaron.v1@v1.3.9/router.go:303 (0x8493e5) gopkg.in/macaron.v1@v1.3.9/macaron.go:220 (0x841fca) net/http/server.go:2836 (0x7a79b2) net/http/server.go:1924 (0x7a341b) runtime/asm_amd64.s:1373 (0x46f9f0)