From f294919d809246d4681c8f71f836eb9b5bf2615e Mon Sep 17 00:00:00 2001 From: Robert Nagy Date: Sun, 6 Sep 2020 13:29:55 +0200 Subject: [PATCH 1/2] docs: add notes about pipelining --- README.md | 9 ++++++--- 1 file changed, 6 insertions(+), 3 deletions(-) diff --git a/README.md b/README.md index 14e63bbf88e..1165fd9a930 100644 --- a/README.md +++ b/README.md @@ -37,7 +37,8 @@ The benchmark is a simple `hello world` [example](benchmarks/index.js) without p ### `new undici.Client(url, opts)` -A basic HTTP/1.1 client, mapped on top a single TCP/TLS connection. +A basic HTTP/1.1 client, mapped on top a single TCP/TLS connection. Pipelining is disabled +by default. `url` can be a string or a [`URL`](https://nodejs.org/api/url.html#url_class_url) object. It should only include the protocol, hostname, and the port. @@ -69,8 +70,10 @@ Options: Default: `1e3` milliseconds (1s). - `pipelining: Number`, the amount of concurrent requests to be sent over the - single TCP/TLS connection according to - [RFC7230](https://tools.ietf.org/html/rfc7230#section-6.3.2). + single TCP/TLS connection according to [RFC7230](https://tools.ietf.org/html/rfc7230#section-6.3.2). + Carefully consider your workload and environment before enabling concurrent requests + as pipelining may reduce performance if used incorrectly. Pipelining is sensitive + to network stack settings as well as head of line blocking caused by long running requests. Default: `1`. - `tls: Object|Null`, an options object which in the case of `https` will be passed to From 3e8487c42b74b37be21059e0c629a39bbeeba8b2 Mon Sep 17 00:00:00 2001 From: Robert Nagy Date: Sun, 6 Sep 2020 14:51:22 +0200 Subject: [PATCH 2/2] Apply suggestions from code review --- README.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/README.md b/README.md index 1165fd9a930..99ee98d65bd 100644 --- a/README.md +++ b/README.md @@ -73,7 +73,7 @@ Options: single TCP/TLS connection according to [RFC7230](https://tools.ietf.org/html/rfc7230#section-6.3.2). Carefully consider your workload and environment before enabling concurrent requests as pipelining may reduce performance if used incorrectly. Pipelining is sensitive - to network stack settings as well as head of line blocking caused by long running requests. + to network stack settings as well as head of line blocking caused by e.g. long running requests. Default: `1`. - `tls: Object|Null`, an options object which in the case of `https` will be passed to