.NET Core vs Iris MVC vs Iris (classic API with Handlers)

No need to format using Writef on benchmarks for a simple string value without dynamic text, just use the WriteString which is the correct function for these apps.


Former-commit-id: 896ec514570d533d8da91af3ad199fc4f823fe74
This commit is contained in:
kataras 2017-08-19 07:11:30 +03:00
parent ca4c66d5b4
commit 151e38d5c8
8 changed files with 32 additions and 24 deletions

View File

@ -5,7 +5,7 @@
## Software ## Software
* OS: Microsoft **Windows** [Version **10**.0.15063] * OS: Microsoft **Windows** [Version **10**.0.15063], power plan is "High performance"
* HTTP Benchmark Tool: https://github.com/codesenberg/bombardier, latest version **1.1** * HTTP Benchmark Tool: https://github.com/codesenberg/bombardier, latest version **1.1**
* **.NET Core**: https://www.microsoft.com/net/core, latest version **2.0** * **.NET Core**: https://www.microsoft.com/net/core, latest version **2.0**
* **Iris**: https://github.com/kataras/iris, latest version **8.3** built with [go1.8.3](https://golang.org) * **Iris**: https://github.com/kataras/iris, latest version **8.3** built with [go1.8.3](https://golang.org)
@ -25,15 +25,15 @@ Application started. Press Ctrl+C to shut down.
```bash ```bash
$ bombardier -c 125 -n 5000000 http://localhost:5000/api/values/5 $ bombardier -c 125 -n 5000000 http://localhost:5000/api/values/5
Bombarding http://localhost:5000/api/values/5 with 5000000 requests using 125 connections Bombarding http://localhost:5000/api/values/5 with 5000000 requests using 125 connections
5000000 / 5000000 [====================================================================================] 100.00% 2m39s 5000000 / 5000000 [=====================================================================================] 100.00% 2m8s
Done! Done!
Statistics Avg Stdev Max Statistics Avg Stdev Max
Reqs/sec 31532.63 10360.09 259792 Reqs/sec 39311.56 11744.49 264000
Latency 3.99ms 2.32ms 297.21ms Latency 3.19ms 1.61ms 229.73ms
HTTP codes: HTTP codes:
1xx - 0, 2xx - 5000000, 3xx - 0, 4xx - 0, 5xx - 0 1xx - 0, 2xx - 5000000, 3xx - 0, 4xx - 0, 5xx - 0
others - 0 others - 0
Throughput: 6.89MB/s Throughput: 8.61MB/s
``` ```
> 127210K Memory (private working set) > 127210K Memory (private working set)
@ -48,17 +48,17 @@ Application started. Press CTRL+C to shut down.
```bash ```bash
$ bombardier -c 125 -n 5000000 http://localhost:5000/api/values/5 $ bombardier -c 125 -n 5000000 http://localhost:5000/api/values/5
Bombarding http://localhost:5000/api/values/5 with 5000000 requests using 125 connections Bombarding http://localhost:5000/api/values/5 with 5000000 requests using 125 connections
5000000 / 5000000 [======================================================================================] 100.00% 58s 5000000 / 5000000 [======================================================================================] 100.00% 47s
Done! Done!
Statistics Avg Stdev Max Statistics Avg Stdev Max
Reqs/sec 86087.86 3432.38 93833 Reqs/sec 105643.81 7687.79 122564
Latency 1.45ms 464.12us 42.53ms Latency 1.18ms 366.55us 22.01ms
HTTP codes: HTTP codes:
1xx - 0, 2xx - 5000000, 3xx - 0, 4xx - 0, 5xx - 0 1xx - 0, 2xx - 5000000, 3xx - 0, 4xx - 0, 5xx - 0
others - 0 others - 0
Throughput: 16.01MB/s Throughput: 19.65MB/s
``` ```
> 11816K Memory (private working set) > 126024K Memory (private working set)
### Iris ### Iris
```bash ```bash
@ -71,17 +71,17 @@ Application started. Press CTRL+C to shut down.
```bash ```bash
$ bombardier -c 125 -n 5000000 http://localhost:5000/api/values/5 $ bombardier -c 125 -n 5000000 http://localhost:5000/api/values/5
Bombarding http://localhost:5000/api/values/5 with 5000000 requests using 125 connections Bombarding http://localhost:5000/api/values/5 with 5000000 requests using 125 connections
5000000 / 5000000 [======================================================================================] 100.00% 48s 5000000 / 5000000 [======================================================================================] 100.00% 45s
Done! Done!
Statistics Avg Stdev Max Statistics Avg Stdev Max
Reqs/sec 102987.54 8333.43 120069 Reqs/sec 110809.98 8209.87 128212
Latency 1.21ms 369.71us 23.52ms Latency 1.13ms 307.86us 18.02ms
HTTP codes: HTTP codes:
1xx - 0, 2xx - 5000000, 3xx - 0, 4xx - 0, 5xx - 0 1xx - 0, 2xx - 5000000, 3xx - 0, 4xx - 0, 5xx - 0
others - 0 others - 0
Throughput: 19.15MB/s Throughput: 20.61MB/s
``` ```
> 11040K Memory (private working set) > 11052K Memory (private working set)
Click [here](screens) to navigate to the screenshots. Click [here](screens) to navigate to the screenshots.
@ -94,8 +94,8 @@ Click [here](screens) to navigate to the screenshots.
* Memory usage - smaller is better. * Memory usage - smaller is better.
* LOC (Lines Of Code) - smaller is better. * LOC (Lines Of Code) - smaller is better.
.NET Core MVC Application, written using 86 lines of code, ran for **2 minutes and 39 seconds** serving **31532.63** requests per second and **3.99ms** latency in average and **297.21ms** max, the memory usage of all these was 127MB (without the dotnet host). .NET Core MVC Application, written using 86 lines of code, ran for **2 minutes and 8 seconds** serving **39311.56** requests per second within **3.19ms** latency in average and **229.73ms** max, the memory usage of all these was 126MB (without the dotnet host).
Iris MVC Application, written using 27 lines of code, ran for **58 seconds** serving **86087.86** requests per second and **1.45ms** latency in average and **42.53ms** max, the memory usage of all these was 12MB. Iris MVC Application, written using 27 lines of code, ran for **47 seconds** serving **105643.71** requests per second within **1.18ms** latency in average and **22.01ms** max, the memory usage of all these was 12MB.
Iris Application, written using 22 lines of code, ran for **48 seconds** serving **102987.54** requests per second and **1.21ms** latency in average and **23.52ms** max, the memory usage of all these was 11MB. Iris Application, written using 22 lines of code, ran for **45 seconds** serving **110809.98** requests per second within **1.13ms** latency in average and **18.02ms** max, the memory usage of all these was 11MB.

View File

@ -11,7 +11,7 @@ type ValuesController struct {
// Get handles "GET" requests to "api/values/{id}". // Get handles "GET" requests to "api/values/{id}".
func (vc *ValuesController) Get() { func (vc *ValuesController) Get() {
// id,_ := vc.Params.GetInt("id") // id,_ := vc.Params.GetInt("id")
vc.Ctx.Writef("value") vc.Ctx.WriteString("value")
} }
// Put handles "PUT" requests to "api/values/{id}". // Put handles "PUT" requests to "api/values/{id}".

View File

@ -18,7 +18,7 @@ func main() {
// getHandler handles "GET" requests to "api/values/{id}". // getHandler handles "GET" requests to "api/values/{id}".
func getHandler(ctx context.Context) { func getHandler(ctx context.Context) {
// id,_ := vc.Params.GetInt("id") // id,_ := vc.Params.GetInt("id")
ctx.Writef("value") ctx.WriteString("value")
} }
// putHandler handles "PUT" requests to "api/values/{id}". // putHandler handles "PUT" requests to "api/values/{id}".

Binary file not shown.

Before

Width:  |  Height:  |  Size: 11 KiB

After

Width:  |  Height:  |  Size: 12 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 11 KiB

After

Width:  |  Height:  |  Size: 11 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 11 KiB

After

Width:  |  Height:  |  Size: 11 KiB

View File

@ -1452,7 +1452,6 @@ func (ctx *context) Write(rawBody []byte) (int, error) {
// //
// Returns the number of bytes written and any write error encountered. // Returns the number of bytes written and any write error encountered.
func (ctx *context) Writef(format string, a ...interface{}) (n int, err error) { func (ctx *context) Writef(format string, a ...interface{}) (n int, err error) {
ctx.ContentType(contentTextHeaderValue)
return ctx.writer.Writef(format, a...) return ctx.writer.Writef(format, a...)
} }

View File

@ -115,13 +115,22 @@ func (w *GzipResponseWriter) Write(contents []byte) (int, error) {
// //
// Returns the number of bytes written and any write error encountered. // Returns the number of bytes written and any write error encountered.
func (w *GzipResponseWriter) Writef(format string, a ...interface{}) (n int, err error) { func (w *GzipResponseWriter) Writef(format string, a ...interface{}) (n int, err error) {
return fmt.Fprintf(w, format, a...) n, err = fmt.Fprintf(w, format, a...)
if err == nil {
w.ResponseWriter.Header().Set(contentTextHeaderValue, "text/plain")
}
return
} }
// WriteString prepares the string data write to the gzip writer and finally to its // WriteString prepares the string data write to the gzip writer and finally to its
// underline response writer, returns the uncompressed len(contents). // underline response writer, returns the uncompressed len(contents).
func (w *GzipResponseWriter) WriteString(s string) (int, error) { func (w *GzipResponseWriter) WriteString(s string) (n int, err error) {
return w.Write([]byte(s)) n, err = w.Write([]byte(s))
if err == nil {
w.ResponseWriter.Header().Set(contentTextHeaderValue, "text/plain")
}
return
} }
// WriteNow compresses and writes that data to the underline response writer, // WriteNow compresses and writes that data to the underline response writer,