2016-10-20 20:30:53 +02:00
|
|
|
+++
|
|
|
|
title = "Customization"
|
|
|
|
description = "Customizing Echo"
|
2016-11-21 00:16:22 +02:00
|
|
|
[menu.main]
|
2016-10-20 20:30:53 +02:00
|
|
|
name = "Customization"
|
|
|
|
parent = "guide"
|
|
|
|
weight = 3
|
|
|
|
+++
|
|
|
|
|
2016-12-16 04:44:06 +02:00
|
|
|
## Debug
|
2016-10-20 20:30:53 +02:00
|
|
|
|
2016-12-16 04:44:06 +02:00
|
|
|
`Echo#Debug` can be used to enable / disable debug mode. Debug mode sets the log level
|
|
|
|
to `DEBUG`.
|
2016-10-20 20:30:53 +02:00
|
|
|
|
2016-11-17 08:46:00 +02:00
|
|
|
## Logging
|
2016-10-20 20:30:53 +02:00
|
|
|
|
2016-11-17 08:46:00 +02:00
|
|
|
### Log Output
|
2016-10-20 20:30:53 +02:00
|
|
|
|
2016-12-15 21:08:56 +02:00
|
|
|
`Echo#Logger.SetOutput(io.Writer)` can be used to set the output destination for
|
|
|
|
the logger. Default value is `os.Stdout`
|
2016-10-20 20:30:53 +02:00
|
|
|
|
2016-12-16 04:44:06 +02:00
|
|
|
To completely disabl logs use `Echo#Logger.SetOutput(io.Discard)` or `Echo#Logger.SetLevel(log.OFF)`
|
2016-10-20 20:30:53 +02:00
|
|
|
|
2016-11-17 08:46:00 +02:00
|
|
|
### Log Level
|
2016-10-20 20:30:53 +02:00
|
|
|
|
2016-12-15 21:08:56 +02:00
|
|
|
`Echo#Logger.SetLevel(log.Lvl)` can be used to set the log level for the logger.
|
2016-12-16 04:44:06 +02:00
|
|
|
Default value is `OFF`. Possible values:
|
2016-10-20 20:30:53 +02:00
|
|
|
|
2016-11-13 19:36:57 +02:00
|
|
|
- `DEBUG`
|
|
|
|
- `INFO`
|
|
|
|
- `WARN`
|
|
|
|
- `ERROR`
|
|
|
|
- `OFF`
|
2016-10-20 20:30:53 +02:00
|
|
|
|
2016-12-16 04:44:06 +02:00
|
|
|
### Custom Logger
|
|
|
|
|
|
|
|
Logging is implemented using `echo.Logger` interface which allows you to register
|
|
|
|
a custom logger using `Echo#Logger`.
|
|
|
|
|
|
|
|
## Custom Server
|
|
|
|
|
2017-01-04 21:39:28 +02:00
|
|
|
### Using `Echo#StartServer()`
|
2016-12-16 04:44:06 +02:00
|
|
|
|
|
|
|
*Example*
|
|
|
|
|
|
|
|
```go
|
|
|
|
s := &http.Server{
|
|
|
|
Addr: ":1323",
|
|
|
|
ReadTimeout: 20 * time.Minute,
|
|
|
|
WriteTimeout: 20 * time.Minute,
|
|
|
|
}
|
|
|
|
e.Logger.Fatal(e.StartServer(s))
|
|
|
|
```
|
|
|
|
|
2017-01-04 21:39:28 +02:00
|
|
|
### Using `http.ListenAndServe*()`
|
|
|
|
|
|
|
|
|
|
|
|
*Example*
|
|
|
|
|
|
|
|
```go
|
|
|
|
e := echo.New()
|
|
|
|
e.GET("/", func(c echo.Context) error {
|
|
|
|
return c.JSON(http.StatusOK, "OK")
|
|
|
|
})
|
|
|
|
s := &http.Server{
|
|
|
|
Handler: e,
|
|
|
|
Addr: ":1323",
|
|
|
|
}
|
|
|
|
e.Logger.Fatal(s.ListenAndServe())
|
|
|
|
```
|
|
|
|
|
|
|
|
> This setup will bypass auto-tls and graceful shutdown.
|
|
|
|
|
2016-12-16 04:44:06 +02:00
|
|
|
## Disable HTTP/2
|
|
|
|
|
|
|
|
`Echo#DisableHTTP2` can be used disable HTTP/2 protocol.
|
|
|
|
|
|
|
|
## Read Timeout
|
|
|
|
|
|
|
|
`Echo#ReadTimeout` can be used to set the maximum duration before timing out read
|
|
|
|
of the request.
|
|
|
|
|
|
|
|
## Write Timeout
|
|
|
|
|
|
|
|
`Echo#WriteTimeout` can be used to set the maximum duration before timing out write
|
|
|
|
of the response.
|
2016-12-15 21:08:56 +02:00
|
|
|
|
2016-12-16 04:44:06 +02:00
|
|
|
## Shutdown Timeout
|
|
|
|
|
|
|
|
`Echo#ShutdownTimeout` can be used to set the maximum duration to wait until killing
|
|
|
|
active requests and stopping the server. If timeout is 0, the server never times
|
|
|
|
out. It waits for all active requests to finish.
|
|
|
|
|
|
|
|
## Validator
|
|
|
|
|
|
|
|
`Echo#Validator` can be used to register a validator for performing data validation
|
|
|
|
on request payload.
|
|
|
|
|
|
|
|
[Learn more](/guide/request#validate-data)
|
|
|
|
|
|
|
|
## Custom Binder
|
|
|
|
|
|
|
|
`Echo#Binder` can be used to register a custom binder for binding request payload.
|
|
|
|
|
|
|
|
[Learn more](/guide/request/#custom-binder)
|
|
|
|
|
|
|
|
## Renderer
|
|
|
|
|
|
|
|
`Echo#Renderer` can be used to register a renderer for template rendering.
|
|
|
|
|
|
|
|
[Learn more](/guide/templates)
|
|
|
|
|
|
|
|
## HTTP Error Handler
|
|
|
|
|
|
|
|
`Echo#HTTPErrorHandler` can be used to register a custom http error handler.
|
|
|
|
|
|
|
|
[Learn more](/guide/error-handling)
|