Commit Graph

1151 Commits

Author SHA1 Message Date
Joe Wilm
34c4d72712 fix(client): Always register for hup 2016-10-13 14:38:19 -07:00
Joe Wilm
ef4c08c9e9 fix(client): Handle connection error
Previously, the connection would be kept alive if there was a connect
error. Now it's closed immediately.
2016-10-13 14:38:10 -07:00
Sean McArthur
27a480c327 Merge pull request #930 from jwilm/handle-keep-alive-hangup
fix(conn): Handle remote hangup
2016-10-10 16:24:37 -07:00
Joe Wilm
9652a42d45 fix(conn): Handle remote hangup
Not handling this was an issue for keep-alive connections because
requests would get assigned to a closed connection and then immediately
error. Handling the HUP event makes this situation much less likely. It
is still possible however; consider the situation where a HUP arrives
while the event loop is busy processing new requests to add. The
connection is disconnected, but the HUP hasn't been processed, and a
request could be assigned to it. This case is, however, unlikely.
2016-10-10 15:44:51 -07:00
Sean McArthur
c2734c6330 Merge pull request #920 from gsquire/referrer-update
Referrer-Policy Header
2016-10-08 18:22:45 -07:00
Sean McArthur
73da844401 Merge pull request #925 from jwilm/fix-spurious-timeouts
fix(http): Connection checks for spurious timeouts
2016-10-08 13:28:50 -07:00
Garrett Squire
7b558ae87a feat(headers): support multiple values for Referrer-Policy header
Closes #882
2016-10-08 11:10:07 -07:00
Joe Wilm
934f2c481b fix(http): Connection checks for spurious timeouts
We've been seeing a strange number of timeouts in our benchmarking.
Handling spurious timeouts as in this patch seems to fix it!

Note that managing the `timeout_start` needs to be done carefully. If
the current time is provided in the wrong place, it's possible requests
would never timeout.
2016-10-07 17:59:47 -07:00
Sean McArthur
588ef9d252 Merge pull request #923 from jwilm/fix-stack-overflow
fix(http): stackoverflow in Conn::ready
2016-10-06 18:31:09 -07:00
Joe Wilm
c32d0e9adf fix(http): stackoverflow in Conn::ready
I've had a couple of instances during stress testing now where
Conn::ready would overflow its stack due to recursing on itself. This
moves subsequent calls to ready() into a loop outside the function.
2016-10-06 18:02:26 -07:00
Shane Gibbs
8672ec5a36 fix(http): make Chunked decoder resilient in an async world 2016-10-06 15:47:03 -07:00
Sean McArthur
0fad665dda Merge pull request #922 from jwilm/configurable-dns-worker-count
feat(client): DNS worker count is configurable
2016-10-06 15:45:56 -07:00
Sean McArthur
37daf1abcb Merge pull request #921 from jwilm/fix-keep-alive
fix(client): keep-alive works as intended now
2016-10-06 15:01:24 -07:00
Joe Wilm
138e1643e8 feat(client): DNS worker count is configurable
When loading up a client suddenly with thousands of connections, the
default DNS worker count of four cannot keep up and many requests
timeout as a result. Most people don't need a large pool, so making this
configurable is a natural choice.
2016-10-06 14:50:30 -07:00
Joe Wilm
15d9da5eb9 fix(client): keep-alive works as intended now
We observed an issue where connection were not ever entering the
keep-alive state due to a bug with `State::update`. The issue is
resolved with resetting the write state to KeepAlive when it arrives as
KeepAlive. Otherwise, it would be marked incorrectly as Closed.

The `trace!` lines in here are useful for debugging keep-alive issues so
I've left them in.
2016-10-06 14:04:01 -07:00
Sean McArthur
f9f13ea317 Merge pull request #919 from jwilm/name-dns-threads
Spawn client DNS threads with descriptive name
2016-10-01 14:49:00 -07:00
Joe Wilm
b4c65086af fix(client): Spawn DNS threads with name
Resolves #918.
2016-10-01 12:19:06 -07:00
Sean McArthur
a6064a639a Merge pull request #917 from gsquire/export-ParseError
Issue 914
2016-09-23 09:45:12 -07:00
Garrett Squire
3636a3e855 refactor(error): export url::ParseError in hyper's error module
Closes #914
2016-09-22 15:39:36 -07:00
Sean McArthur
bed4815d69 Merge pull request #916 from jwilm/full-slab-evict-idle
Evict idle connections when client is full
2016-09-22 10:39:33 -07:00
Joe Wilm
27cab3766d fix(client): Evict idle connections when full
In the scenario where a request is started on the `Client`, the client
has a full slab, and sockets for a *different* domain are idling in
keep-alive, the new request would previously cause the client to panic!.

This patch adds a `spawn_error` handler which attempts to evict an idle
connection to make space for the new request. If space cannot be made,
the error handler is run (passed `Error::Full`) and the `Handler` is
dropped.

This is a breaking change because of the new variant of `Error`.

Some inefficient use of `Vec` in the client was replaced with `VecDeque`
to support push/pop from either end.
2016-09-21 17:52:38 -07:00
Sean McArthur
8c6e6f51ab Merge pull request #910 from smithsps/feat-warning-header
feat(headers): add Warning header
2016-09-06 15:59:52 -07:00
Simon Smith
69894d1994 feat(headers): add Warning header
Implements Warning header from RFC7234
Closes #883
2016-09-05 14:35:48 -04:00
Ahmed Charles
8b3c120684 feat(server): add path() and query() to Request
Closes #896 
Closes #897

BREAKING CHANGE: `RequestUri::AbsolutePath` variant is changed to a struct variant. Consider using `req.path()` or `req.query()` to get the relevant slice.
2016-08-29 13:45:38 -07:00
Sean McArthur
a228486a85 Merge pull request #905 from YetAnotherMinion/enh-update_num_cpus_version
refactor(version): bump version of num_cpus to 1.0
2016-08-27 19:43:22 -07:00
YetAnotherMinion
c8b48c7efd refactor(version): bump version of num_cpus to 1.0 2016-08-27 14:03:24 -04:00
Markus Unterwaditzer
9375addba0 feat(headers): Headers::remove returns the Header
Closes #891

BREAKING CHANGE: `Headers.remove()` used to return a `bool`,
  it now returns `Option<H>`. To determine if a a header exists,
  switch to `Headers.has()`.
2016-08-23 16:46:07 -04:00
Sean McArthur
74136de960 Merge pull request #889 from aidanhs/aphs-not-v1-warning
Note on pre 1.0
2016-08-11 15:45:01 -07:00
Aidan Hobson Sayers
d53e033704 docs(version): note on pre 1.0 stability 2016-08-11 22:42:28 +01:00
Sean McArthur
0ce83dfbb3 Merge pull request #878 from nox/serde
Update serde to 0.8
2016-08-07 10:29:22 -07:00
Sean McArthur
c497dfcc93 Merge pull request #879 from nox/cookie
Update cookie to 0.3
2016-08-07 10:29:08 -07:00
Sean McArthur
f51b799023 Merge pull request #884 from hyperium/perf
A couple performance boosts
2016-08-06 10:58:36 -07:00
Sean McArthur
a3a815c09c perf(http): reduce server loops when headers and body are ready 2016-08-06 00:11:45 -07:00
Sean McArthur
523b890a19 fix(server): support HTTP/1.1 pipelining 2016-08-06 00:10:46 -07:00
Sean McArthur
12dac9bdba perf(http): encoder headers with a faster fmt::Write 2016-08-06 00:09:00 -07:00
Anthony Ramine
dc03ca188a chore(version): Update cookie to 0.3 2016-08-02 09:54:40 +02:00
Anthony Ramine
de921d08fe chore(version): Update serde to 0.8 2016-08-02 09:39:10 +02:00
Sean McArthur
9456738ee1 Merge pull request #877 from jongiddy/guide-save-receiver
Fix guide example to save receiver for later use by response handler.
2016-07-31 23:54:12 -07:00
Jonathan Giddy
ea1dccff59 docs(guide): fix guide example to save receiver for later use by response handler 2016-07-31 17:24:51 +01:00
Sean McArthur
81e7bf4155 refactor(http): call on_error for more error cases 2016-07-29 14:25:12 -07:00
Joonas Koivunen
13c5bf66c3 feat(headers): add Content-Location header
Closes #870
2016-07-28 09:59:33 -07:00
Sean McArthur
1b4a2b7e6f Merge pull request #876 from leodasvacas/conn-refactor
Dedup code in connection state update.
2016-07-27 16:49:44 -07:00
leonardo.yvens
211b408b92 style(http): Rustfmt State.update 2016-07-27 10:46:04 -03:00
leonardo.yvens
9f249bbee8 refactor(http): Dedup code in connection state update. 2016-07-27 10:45:57 -03:00
leonardo.yvens
c6eea3761b refactor(http): Remove new_state and use nested match for http1 in connection state update. 2016-07-27 10:45:51 -03:00
Sean McArthur
e5841365dd Merge pull request #874 from hyperium/guide
docs(guide): adjust styles of the guides
2016-07-26 09:45:51 -07:00
Sean McArthur
81e6e98d80 docs(guide): adjust styles of the guides 2016-07-26 08:55:08 -07:00
Sean McArthur
6f0921ed94 Merge pull request #873 from hyperium/guide
docs(guide): add meat to the Server Guide
2016-07-26 00:27:51 -07:00
Sean McArthur
12c69b5dd0 docs(guide): add meat to the Server Guide
Closes #806
2016-07-25 20:23:44 -07:00
Sean McArthur
50ccdaa7e7 feat(header): introduce header::Raw (#869)
The Raw type repesents the raw bytes of a header-value.

Having a special type allows a couple of benefits:

- The exact representation has become private, allowing "uglier"
internals. Specifically, since the common case is for a header to only
have 1 line of bytes, an enum is used to skip allocating a Vec for only
1 line. Additionally, a Cow<'static, [u8]> is used, so static bytes
don't require a copy. Finally, since we can use static bytes, when
parsing, we can compare the incoming bytes against a couple of the most
common header-values, and possibly remove another copy.

- As its own type, the `Headers.set_raw` method can be generic over
`Into<Raw>`, which allows for more ergnomic method calls.

BREAKING CHANGE: `Header::parse_header` now receives `&Raw`, instead of
  a `&[Vec<u8>]`. `Raw` provides several methods to ease using it, but
  may require some changes to existing code.
2016-07-23 12:54:16 -07:00