Log paket menyediakan cara untuk menulis dan membuat kueri log aplikasi dari dalam aplikasi App Engine.
Contoh:
c := appengine.NewContext(r) query := &log.Query{ AppLogs: true, Versions: []string{"1"}, } for results := query.Run(c); ; { record, err := results.Next() if err == log.Done { log.Infof(c, "Done processing results") break } if err != nil { log.Errorf(c, "Failed to retrieve next log: %v", err) break } log.Infof(c, "Saw record %v", record) }
Variabel
Selesai
Done akan ditampilkan ketika iterasi kueri telah selesai.
Functions
func Criticalf
Criticalf seperti Debugf, tetapi untuk tingkat Kritis.
func Debugf
Debugf memformat argumennya sesuai dengan format, serupa dengan fmt.Printf, dan mencatat teks sebagai pesan log di tingkat Debug. Pesan tersebut akan dikaitkan dengan permintaan yang ditautkan dengan konteks yang diberikan.
func Errorf
Errorf mirip dengan Debugf, tetapi untuk tingkat Error.
func Infof
Infof seperti Debugf, tetapi untuk tingkat Info.
func Warningf
Warningf sama seperti Debugf, tetapi untuk tingkat Warning.
AppLog
AppLog mewakili satu log tingkat aplikasi.
Kueri
type Query struct {
// Start time specifies the earliest log to return (inclusive).
StartTime time.Time
// End time specifies the latest log to return (exclusive).
EndTime time.Time
// Offset specifies a position within the log stream to resume reading from,
// and should come from a previously returned Record's field of the same name.
Offset []byte
// Incomplete controls whether active (incomplete) requests should be included.
Incomplete bool
// AppLogs indicates if application-level logs should be included.
AppLogs bool
// ApplyMinLevel indicates if MinLevel should be used to filter results.
ApplyMinLevel bool
// If ApplyMinLevel is true, only logs for requests with at least one
// application log of MinLevel or higher will be returned.
MinLevel int
// Versions is the major version IDs whose logs should be retrieved.
// Logs for specific modules can be retrieved by the specifying versions
// in the form "module:version"; the default module is used if no module
// is specified.
Versions []string
// A list of requests to search for instead of a time-based scan. Cannot be
// combined with filtering options such as StartTime, EndTime, Offset,
// Incomplete, ApplyMinLevel, or Versions.
RequestIDs []string
}
Kueri menentukan kueri log.
func (*Query) Run
Run akan memulai kueri untuk data log, yang berisi informasi log tingkat permintaan dan aplikasi.
Record
type Record struct {
AppID string
ModuleID string
VersionID string
RequestID []byte
IP string
Nickname string
AppEngineRelease string
// The time when this request started.
StartTime time.Time
// The time when this request finished.
EndTime time.Time
// Opaque cursor into the result stream.
Offset []byte
// The time required to process the request.
Latency time.Duration
MCycles int64
Method string
Resource string
HTTPVersion string
Status int32
// The size of the request sent back to the client, in bytes.
ResponseSize int64
Referrer string
UserAgent string
URLMapEntry string
Combined string
Host string
// The estimated cost of this request, in dollars.
Cost float64
TaskQueueName string
TaskName string
WasLoadingRequest bool
PendingTime time.Duration
Finished bool
AppLogs []AppLog
// Mostly-unique identifier for the instance that handled the request if available.
InstanceID string
}
Data berisi semua informasi untuk satu permintaan web.
Result
type Result struct {
// contains filtered or unexported fields
}
Result mewakili hasil dari suatu kueri.
func (*Result) Next
Next menampilkan catatan log berikutnya,