Go to file
Trustin Lee 4d6ab1d30d Fix missing trailing data on HTTP client upgrade
Motivation:

When HttpClientUpgradeHandler upgrades from HTTP/1 to another protocol,
it performs a two-step opertion:

1. Remove the SourceCodec (HttpClientCodec)
2. Add the UpgradeCodec

When HttpClientCodec is removed from the pipeline, the decoder being
removed triggers channelRead() event with the data left in its
cumulation buffer. However, this is not received by the UpgradeCodec
becuase it's not added yet. e.g. HTTP/2 SETTINGS frame sent by the
server can be missed out.

To fix the problem, we need to reverse the steps:

1. Add the UpgradeCodec
2. Remove the SourceCodec

However, this does not work as expected either, because UpgradeCodec can
send a greeting message such as HTTP/2 Preface. Such a greeting message
will be handled by the SourceCodec and will trigger an 'unsupported
message type' exception.

To fix the problem really, we need to make the upgrade process 3-step:

1. Remove/disable the encoder of SourceCodec
2. Add the UpgradeCodec
3. Remove the SourceCodec

Modifications:

- Add SourceCodec.prepareUpgradeFrom() so that SourceCodec can remove or
  disable its encoder
- Implement HttpClientCodec.prepareUpgradeFrom() properly
- Miscellaneous:
  - Log the related channel as well When logging the failure to send a
    GOAWAY

Result:

Cleartext HTTP/1-to-HTTP/2 upgrade works again.
2016-02-01 15:52:37 +01:00
all [maven-release-plugin] prepare for next development iteration 2016-01-21 15:35:55 +01:00
buffer [maven-release-plugin] prepare for next development iteration 2016-01-21 15:35:55 +01:00
codec [maven-release-plugin] prepare for next development iteration 2016-01-21 15:35:55 +01:00
codec-dns [maven-release-plugin] prepare for next development iteration 2016-01-21 15:35:55 +01:00
codec-haproxy [maven-release-plugin] prepare for next development iteration 2016-01-21 15:35:55 +01:00
codec-http Fix missing trailing data on HTTP client upgrade 2016-02-01 15:52:37 +01:00
codec-http2 Fix missing trailing data on HTTP client upgrade 2016-02-01 15:52:37 +01:00
codec-memcache Use AbstractReferenceCounted to clean up the codes for codec-memcache 2016-02-01 15:51:08 +01:00
codec-mqtt [maven-release-plugin] prepare for next development iteration 2016-01-21 15:35:55 +01:00
codec-socks [maven-release-plugin] prepare for next development iteration 2016-01-21 15:35:55 +01:00
codec-stomp [maven-release-plugin] prepare for next development iteration 2016-01-21 15:35:55 +01:00
codec-xml [maven-release-plugin] prepare for next development iteration 2016-01-21 15:35:55 +01:00
common Add a reusable ArrayList to InternalThreadLocalMap 2016-02-01 15:49:28 +01:00
example Allow to specify tcnative artifactId and verion to allow run tests easily with different tcnative flavors 2016-01-29 22:27:19 +01:00
handler Add a reusable ArrayList to InternalThreadLocalMap 2016-02-01 15:49:28 +01:00
handler-proxy [maven-release-plugin] prepare for next development iteration 2016-01-21 15:35:55 +01:00
license added support for Protobuf codec nano runtime 2016-01-19 21:39:17 +01:00
microbench [maven-release-plugin] prepare for next development iteration 2016-01-21 15:35:55 +01:00
resolver [maven-release-plugin] prepare for next development iteration 2016-01-21 15:35:55 +01:00
resolver-dns Add a reusable ArrayList to InternalThreadLocalMap 2016-02-01 15:49:28 +01:00
tarball [maven-release-plugin] prepare for next development iteration 2016-01-21 15:35:55 +01:00
testsuite Allow to specify tcnative artifactId and verion to allow run tests easily with different tcnative flavors 2016-01-29 22:27:19 +01:00
testsuite-osgi [maven-release-plugin] prepare for next development iteration 2016-01-21 15:35:55 +01:00
transport OioServerChannel Default Max Messages Per Read Too High 2016-01-29 11:34:00 -08:00
transport-native-epoll Allow to specify tcnative artifactId and verion to allow run tests easily with different tcnative flavors 2016-01-29 22:27:19 +01:00
transport-rxtx [maven-release-plugin] prepare for next development iteration 2016-01-21 15:35:55 +01:00
transport-sctp OioServerChannel Default Max Messages Per Read Too High 2016-01-29 11:34:00 -08:00
transport-udt [maven-release-plugin] prepare for next development iteration 2016-01-21 15:35:55 +01:00
.fbprefs Updated Find Bugs configuration 2009-03-04 10:33:09 +00:00
.gitignore Add JVM crash logs to .gitignore 2014-05-18 21:36:54 +09:00
.travis.yml Travis CI branch whitelisting 2013-03-11 09:55:43 +09:00
CONTRIBUTING.md Move the pull request guide to the developer guide 2014-03-12 13:13:58 +09:00
LICENSE.txt Relicensed to Apache License v2 2009-08-28 07:15:49 +00:00
NOTICE.txt added support for Protobuf codec nano runtime 2016-01-19 21:39:17 +01:00
pom.xml Allow to specify tcnative artifactId and verion to allow run tests easily with different tcnative flavors 2016-01-29 22:27:19 +01:00
README.md Fix the 'branches to look' section 2015-10-27 13:59:11 +01:00
run-example.sh Add HTTP/2 Netty tiles example 2015-05-18 14:16:54 -07:00

Netty Project

Netty is an asynchronous event-driven network application framework for rapid development of maintainable high performance protocol servers & clients.

How to build

For the detailed information about building and developing Netty, please visit the developer guide. This page only gives very basic information.

You require the following to build Netty:

Note that this is build-time requirement. JDK 5 (for 3.x) or 6 (for 4.0+) is enough to run your Netty-based application.

Branches to look

The 'master' branch is where the development of the latest major version lives on. The development of all other versions takes place in each branch whose name is identical to <majorVersion>.<minorVersion>. For example, the development of 3.9 and 4.0 resides in the branch '3.9' and the branch '4.0' respectively.