vapor-docs/docs/basics/logging.nl.md

111 lines
4.1 KiB
Markdown

# Loggen
Vapor's logging API is gebouwd bovenop [SwiftLog](https://github.com/apple/swift-log).
Dit betekent dat Vapor compatibel is met alle [backend implementaties](https://github.com/apple/swift-log#backends) van SwiftLog.
## Logger
Instanties van `Logger` worden gebruikt voor het wegschrijven van log berichten. Vapor biedt een paar eenvoudige manieren om toegang te krijgen tot een logger.
### Verzoek
Elk inkomende `Request` heeft een unieke logger die je moet gebruiken voor alle logs die specifiek zijn voor dat verzoek.
```swift
app.get("hello") { req -> String in
req.logger.info("Hello, logs!")
return "Hello, world!"
}
```
De verzoeklogger bevat een unieke UUID die het inkomende verzoek identificeert om het traceren van logs te vergemakkelijken.
```
[ INFO ] Hello, logs! [request-id: C637065A-8CB0-4502-91DC-9B8615C5D315] (App/routes.swift:10)
```
!!! info
Logger metadata zal alleen getoond worden in debug log level of lager.
### Applicatie
Voor log berichten tijdens het opstarten en configureren van de app, gebruik `Application`'s logger.
```swift
app.logger.info("Setting up migrations...")
app.migrations.use(...)
```
### Aangepaste Logger
In situaties waar je geen toegang hebt tot `Application` of `Request`, kan je een nieuwe `Logger` initialiseren.
```swift
let logger = Logger(label: "dev.logger.my")
logger.info(...)
```
Hoewel aangepaste loggers nog steeds zullen uitvoeren naar je geconfigureerde logboek backend, zullen ze geen belangrijke metadata zoals verzoek UUID bijgevoegd hebben. Gebruik waar mogelijk de verzoek- of applicatiespecifieke loggers.
## Niveaus
SwiftLog ondersteunt verschillende logging niveaus.
|naam|beschrijving|
|-|-|
|trace|Geschikt voor berichten die informatie bevatten die normaal alleen van nut is bij het traceren van de uitvoering van een programma.|
|debug|Geschikt voor berichten die informatie bevatten die normaal alleen nuttig is bij het debuggen van een programma.|
|info|Geschikt voor informatieve berichten.|
|notice|Geschikt voor omstandigheden die geen foutomstandigheden zijn, maar die mogelijk een speciale behandeling vereisen.|
|warning|Geschikt voor berichten die geen foutconditie zijn, maar ernstiger dan een mededeling.|
|error|Geschikt voor foutcondities.|
|critical|Geschikt voor kritieke foutcondities die gewoonlijk onmiddellijke aandacht vereisen.|
Wanneer een `critical` bericht is gelogd, is de logging backend vrij om zwaardere operaties uit te voeren om systeem status vast te leggen (zoals het vastleggen van stack traces) om debugging te vergemakkelijken.
Standaard zal Vapor `info` niveau logging gebruiken. Wanneer de `productie` omgeving wordt gebruikt, zal `notice` worden gebruikt om de performance te verbeteren.
### Log Niveau Veranderen
Ongeacht de omgevingsmodus, kunt u het log-niveau aanpassen om de hoeveelheid geproduceerde logs te vergroten of te verkleinen.
De eerste methode is om de optionele `--log` vlag mee te geven bij het opstarten van je applicatie.
```sh
swift run App serve --log debug
```
De tweede methode is het instellen van de `LOG_LEVEL` omgevingsvariabele.
```sh
export LOG_LEVEL=debug
swift run App serve
```
Beide kunnen worden gedaan in Xcode door het `App` schema te bewerken.
## Configuratie
SwiftLog wordt geconfigureerd door het `LoggingSystem` één keer per proces te bootstrappen. Vapor projecten doen dit meestal in `entrypoint.swift`.
```swift
var env = try Environment.detect()
try LoggingSystem.bootstrap(from: &env)
```
`bootstrap(from:)` is een helper methode van Vapor die de standaard log handler configureert gebaseerd op command-line argumenten en omgevingsvariabelen. De standaard log handler ondersteunt de uitvoer van berichten naar de terminal met ondersteuning voor ANSI kleuren.
### Aangepaste Handler
U kunt Vapor's standaard log handler overschrijven en uw eigen log handler registreren.
```swift
import Logging
LoggingSystem.bootstrap { label in
StreamLogHandler.standardOutput(label: label)
}
```
Alle ondersteunde backends van SwiftLog werken met Vapor. Echter, het veranderen van het log niveau met command-line argumenten en omgevingsvariabelen is alleen compatibel met Vapor's standaard log handler.