mirror of
https://github.com/kataras/iris.git
synced 2025-01-23 10:41:03 +01:00
Update to 4.2.6, read HISTORY.md
This commit is contained in:
parent
27f2ba7be9
commit
000dfbbee2
21
HISTORY.md
21
HISTORY.md
|
@ -5,6 +5,27 @@
|
||||||
## 4.2.5 -> 4.2.6
|
## 4.2.5 -> 4.2.6
|
||||||
|
|
||||||
- **CHANGE**: Updater (See 4.2.4 and 4.2.3) runs in its own goroutine now, unless the `iris.Config.CheckForUpdatesSync` is true.
|
- **CHANGE**: Updater (See 4.2.4 and 4.2.3) runs in its own goroutine now, unless the `iris.Config.CheckForUpdatesSync` is true.
|
||||||
|
- **ADDED**: To align with fasthttp server's configuration, iris has these new Server Configuration's fields, which allows you to set a type of rate limit:
|
||||||
|
```go
|
||||||
|
// Maximum number of concurrent client connections allowed per IP.
|
||||||
|
//
|
||||||
|
// By default unlimited number of concurrent connections
|
||||||
|
// may be established to the server from a single IP address.
|
||||||
|
MaxConnsPerIP int
|
||||||
|
|
||||||
|
// Maximum number of requests served per connection.
|
||||||
|
//
|
||||||
|
// The server closes connection after the last request.
|
||||||
|
// 'Connection: close' header is added to the last response.
|
||||||
|
//
|
||||||
|
// By default unlimited number of requests may be served per connection.
|
||||||
|
MaxRequestsPerConn int
|
||||||
|
|
||||||
|
// Usage: iris.ListenTo{iris.OptionServerListeningAddr(":8080"), iris.OptionServerMaxConnsPerIP(300)}
|
||||||
|
// or: iris.ListenTo(iris.ServerConfiguration{ListeningAddr: ":8080", MaxConnsPerIP: 300, MaxRequestsPerConn:100})
|
||||||
|
// for an optional second server with a different port you can always use:
|
||||||
|
// iris.AddServer(iris.ServerConfiguration{ListeningAddr: ":9090", MaxConnsPerIP: 300, MaxRequestsPerConn:100})
|
||||||
|
```
|
||||||
|
|
||||||
## 4.2.4 -> 4.2.5
|
## 4.2.4 -> 4.2.5
|
||||||
|
|
||||||
|
|
|
@ -667,6 +667,27 @@ type ServerConfiguration struct {
|
||||||
// By default response write timeout is unlimited.
|
// By default response write timeout is unlimited.
|
||||||
WriteTimeout time.Duration
|
WriteTimeout time.Duration
|
||||||
|
|
||||||
|
// Maximum number of concurrent client connections allowed per IP.
|
||||||
|
//
|
||||||
|
// By default unlimited number of concurrent connections
|
||||||
|
// may be established to the server from a single IP address.
|
||||||
|
// Usage: iris.ListenTo{iris.OptionServerListeningAddr(":8080"), iris.OptionServerMaxConnsPerIP(300)}
|
||||||
|
// or: iris.ListenTo(iris.ServerConfiguration{ListeningAddr: ":8080", MaxConnsPerIP: 300})
|
||||||
|
// for an optional second server with a different port you can always use:
|
||||||
|
// iris.AddServer(iris.ServerConfiguration{ListeningAddr: ":9090", MaxConnsPerIP: 300})
|
||||||
|
MaxConnsPerIP int
|
||||||
|
|
||||||
|
// Maximum number of requests served per connection.
|
||||||
|
//
|
||||||
|
// The server closes connection after the last request.
|
||||||
|
// 'Connection: close' header is added to the last response.
|
||||||
|
//
|
||||||
|
// By default unlimited number of requests may be served per connection.
|
||||||
|
// Usage: iris.ListenTo{iris.OptionServerListeningAddr(":8080"), iris.OptionServerMaxConnsPerIP(300)}
|
||||||
|
// or: iris.ListenTo(iris.ServerConfiguration{ListeningAddr: ":8080", MaxRequestsPerConn:100})
|
||||||
|
// for an optional second server with a different port you can always use:
|
||||||
|
// iris.AddServer(iris.ServerConfiguration{ListeningAddr: ":9090", MaxRequestsPerConn:100})
|
||||||
|
MaxRequestsPerConn int
|
||||||
// RedirectTo, defaults to empty, set it in order to override the station's handler and redirect all requests to this address which is of form(HOST:PORT or :PORT)
|
// RedirectTo, defaults to empty, set it in order to override the station's handler and redirect all requests to this address which is of form(HOST:PORT or :PORT)
|
||||||
//
|
//
|
||||||
// NOTE: the http status is 'StatusMovedPermanently', means one-time-redirect(the browser remembers the new addr and goes to the new address without need to request something from this server
|
// NOTE: the http status is 'StatusMovedPermanently', means one-time-redirect(the browser remembers the new addr and goes to the new address without need to request something from this server
|
||||||
|
@ -807,6 +828,28 @@ var (
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// OptionServerMaxConnsPerIP Maximum number of concurrent client connections allowed per IP.
|
||||||
|
//
|
||||||
|
// By default unlimited number of concurrent connections
|
||||||
|
// may be established to the server from a single IP address.
|
||||||
|
OptionServerMaxConnsPerIP = func(val int) OptionServerSet {
|
||||||
|
return func(c *ServerConfiguration) {
|
||||||
|
c.MaxConnsPerIP = val
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// OptionServerMaxRequestsPerConn Maximum number of requests served per connection.
|
||||||
|
//
|
||||||
|
// The server closes connection after the last request.
|
||||||
|
// 'Connection: close' header is added to the last response.
|
||||||
|
//
|
||||||
|
// By default unlimited number of requests may be served per connection.
|
||||||
|
OptionServerMaxRequestsPerConn = func(val int) OptionServerSet {
|
||||||
|
return func(c *ServerConfiguration) {
|
||||||
|
c.MaxRequestsPerConn = val
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// RedirectTo, defaults to empty, set it in order to override the station's handler and redirect all requests to this address which is of form(HOST:PORT or :PORT)
|
// RedirectTo, defaults to empty, set it in order to override the station's handler and redirect all requests to this address which is of form(HOST:PORT or :PORT)
|
||||||
//
|
//
|
||||||
// NOTE: the http status is 'StatusMovedPermanently', means one-time-redirect(the browser remembers the new addr and goes to the new address without need to request something from this server
|
// NOTE: the http status is 'StatusMovedPermanently', means one-time-redirect(the browser remembers the new addr and goes to the new address without need to request something from this server
|
||||||
|
@ -927,6 +970,8 @@ func DefaultServerConfiguration() ServerConfiguration {
|
||||||
MaxRequestBodySize: DefaultMaxRequestBodySize,
|
MaxRequestBodySize: DefaultMaxRequestBodySize,
|
||||||
ReadBufferSize: DefaultReadBufferSize,
|
ReadBufferSize: DefaultReadBufferSize,
|
||||||
WriteBufferSize: DefaultWriteBufferSize,
|
WriteBufferSize: DefaultWriteBufferSize,
|
||||||
|
MaxConnsPerIP: 0,
|
||||||
|
MaxRequestsPerConn: 0,
|
||||||
RedirectTo: "",
|
RedirectTo: "",
|
||||||
Virtual: false,
|
Virtual: false,
|
||||||
VListeningAddr: "",
|
VListeningAddr: "",
|
||||||
|
|
2
http.go
2
http.go
|
@ -437,6 +437,8 @@ func (s *Server) Open(h fasthttp.RequestHandler) error {
|
||||||
s.Server.WriteBufferSize = s.Config.WriteBufferSize
|
s.Server.WriteBufferSize = s.Config.WriteBufferSize
|
||||||
s.Server.ReadTimeout = s.Config.ReadTimeout
|
s.Server.ReadTimeout = s.Config.ReadTimeout
|
||||||
s.Server.WriteTimeout = s.Config.WriteTimeout
|
s.Server.WriteTimeout = s.Config.WriteTimeout
|
||||||
|
s.Server.MaxConnsPerIP = s.Config.MaxConnsPerIP
|
||||||
|
s.Server.MaxRequestsPerConn = s.Config.MaxRequestsPerConn
|
||||||
|
|
||||||
if s.Config.RedirectTo != "" {
|
if s.Config.RedirectTo != "" {
|
||||||
// override the handler and redirect all requests to this addr
|
// override the handler and redirect all requests to this addr
|
||||||
|
|
Loading…
Reference in New Issue
Block a user