nghttpx: Update doc

This commit is contained in:
Tatsuhiro Tsujikawa 2015-07-14 23:44:58 +09:00
parent 4fed7a1476
commit a2c78cfc69
1 changed files with 25 additions and 22 deletions

View File

@ -998,7 +998,7 @@ Options:
The options are categorized into several groups. The options are categorized into several groups.
Connections: Connections:
-b, --backend=<HOST>,<PORT>[;<PATTERN>[:...]] -b, --backend=(<HOST>,<PORT>|unix:<PATH>)[;<PATTERN>[:...]]
Set backend host and port. The multiple backend Set backend host and port. The multiple backend
addresses are accepted by repeating this option. UNIX addresses are accepted by repeating this option. UNIX
domain socket can be specified by prefixing path name domain socket can be specified by prefixing path name
@ -1009,27 +1009,27 @@ Connections:
-p is used, <PATTERN>s are ignored. The pattern -p is used, <PATTERN>s are ignored. The pattern
matching is closely designed to ServeMux in net/http matching is closely designed to ServeMux in net/http
package of Go programming language. <PATTERN> consists package of Go programming language. <PATTERN> consists
of path, host + path or just host. The path must starts of path, host + path or just host. The path must start
with "/". If it ends with "/", it matches to the with "/". If it ends with "/", it matches all request
request path whose prefix is the path. To deal with the path in its subtree. To deal with the request to the
request to the directory without trailing slash, pattern directory without trailing slash, the path which ends
which ends with "/" also matches the path if pattern == with "/" also matches the request path which only lacks
path + "/" (e.g., pattern "/foo/" matches path "/foo"). trailing '/' (e.g., path "/foo/" matches request path
If it does not end with "/", it performs exact match "/foo"). If it does not end with "/", it performs exact
against the request path. If host is given, it performs match against the request path. If host is given, it
exact match against the request host. If host alone is performs exact match against the request host. If host
given, "/" is appended to it, so that it matches all alone is given, "/" is appended to it, so that it
paths under the host (e.g., specifying "nghttp2.org" matches all request paths under the host (e.g.,
equals to "nghttp2.org/"). specifying "nghttp2.org" equals to "nghttp2.org/").
Patterns with host take precedence over path only Patterns with host take precedence over patterns with
patterns. Then, longer patterns take precedence over just path. Then, longer patterns take precedence over
shorter ones, breaking a tie by the order of the shorter ones, breaking a tie by the order of the
appearance in the configuration. appearance in the configuration.
If <PATTERN> is omitted, "/" is used as pattern, which If <PATTERN> is omitted, "/" is used as pattern, which
matches all paths (catch-all pattern). The catch-all matches all request paths (catch-all pattern). The
backend must be given. catch-all backend must be given.
When doing a match, nghttpx made some normalization to When doing a match, nghttpx made some normalization to
pattern, request host and path. For host part, they are pattern, request host and path. For host part, they are
@ -1047,15 +1047,18 @@ Connections:
them by ":". Specifying them by ":". Specifying
-b'127.0.0.1,8080;nghttp2.org:www.nghttp2.org' has the -b'127.0.0.1,8080;nghttp2.org:www.nghttp2.org' has the
same effect to specify -b'127.0.0.1,8080;nghttp2.org' same effect to specify -b'127.0.0.1,8080;nghttp2.org'
and -b'127.0.0.1,8080:www.nghttp2.org'. and -b'127.0.0.1,8080;www.nghttp2.org'.
The backend addresses sharing same <PATTERN> are grouped The backend addresses sharing same <PATTERN> are grouped
together forming load balancing group. Since ";" and together forming load balancing group.
":" are used as delimiter, <PATTERN> must not contain
these characters. Since ";" and ":" are used as delimiter, <PATTERN> must
not contain these characters. Since ";" has special
meaning in shell, the option value must be quoted.
Default: )" << DEFAULT_DOWNSTREAM_HOST << "," Default: )" << DEFAULT_DOWNSTREAM_HOST << ","
<< DEFAULT_DOWNSTREAM_PORT << R"( << DEFAULT_DOWNSTREAM_PORT << R"(
-f, --frontend=<HOST>,<PORT> -f, --frontend=(<HOST>,<PORT>|unix:<PATH>)
Set frontend host and port. If <HOST> is '*', it Set frontend host and port. If <HOST> is '*', it
assumes all addresses including both IPv4 and IPv6. assumes all addresses including both IPv4 and IPv6.
UNIX domain socket can be specified by prefixing path UNIX domain socket can be specified by prefixing path