Go to file
Norman Maurer 5fd239c29c Ensure we not log missleading errors if the promise was already failed due errors
Motivation:

In DefaultHttp2ConnectionEncoder we fail the promise in in the FlowControlledData.error(...) method but also add it the CoalescingBufferQueue. Which can lead to have the promise failed by error(...) before it can be failed in CoalescingBufferQueue.

This can lead to confusing and missleading errors in the log like:
    2016-08-12 09:47:43,716       nettyIoExecutorGroup-1-9 [WARN ] PromiseNotifier                - Failed to mark a promise as failure because it's done already: DefaultChannelPromise@374225e0(failure: javax.net.ssl.SSLException: SSLEngine closed already)
    javax.net.ssl.SSLException: SSLEngine closed already
        at io.netty.handler.ssl.SslHandler.wrap(...)(Unknown Source) ~[netty-all-4.1.5.Final-SNAPSHOT.jar:?]

Modifications:

Ensure we only fail the queue (which will also fail the promise).

Result:

No more missleading logs.
2016-08-18 07:17:45 +02:00
all [maven-release-plugin] prepare for next development iteration 2016-07-27 13:29:56 +02:00
buffer [#5645] Allow to create ByteBuf from existing memory address. 2016-08-16 14:16:15 +02:00
codec small performance fixes : unnecessary unboxing operations removed 2016-08-01 07:10:25 +02:00
codec-dns Removed custom split method as it is not effective anymore. 2016-08-01 21:49:33 +02:00
codec-haproxy Removed custom split method as it is not effective anymore. 2016-08-01 21:49:33 +02:00
codec-http Do not return Access-Control-Allow-Headers on Non-Preflight Cors requests 2016-08-16 13:45:04 +02:00
codec-http2 Ensure we not log missleading errors if the promise was already failed due errors 2016-08-18 07:17:45 +02:00
codec-memcache [maven-release-plugin] prepare for next development iteration 2016-07-27 13:29:56 +02:00
codec-mqtt [maven-release-plugin] prepare for next development iteration 2016-07-27 13:29:56 +02:00
codec-redis [maven-release-plugin] prepare for next development iteration 2016-07-27 13:29:56 +02:00
codec-smtp [maven-release-plugin] prepare for next development iteration 2016-07-27 13:29:56 +02:00
codec-socks [maven-release-plugin] prepare for next development iteration 2016-07-27 13:29:56 +02:00
codec-stomp Removed custom split method as it is not effective anymore. 2016-08-01 21:49:33 +02:00
codec-xml [maven-release-plugin] prepare for next development iteration 2016-07-27 13:29:56 +02:00
common [#5645] Allow to create ByteBuf from existing memory address. 2016-08-16 14:16:15 +02:00
example Support Unicode filenames and spaces in directory listing 2016-08-16 09:18:18 +02:00
handler Correctly fail all promises SSLENGINE_CLOSED once the engine is closed 2016-08-17 21:47:00 +02:00
handler-proxy Removed custom split method as it is not effective anymore. 2016-08-01 21:49:33 +02:00
license added support for Protobuf codec nano runtime 2016-01-19 21:39:17 +01:00
microbench HTTP/2 Simplify Headers Decode Bounds Checking 2016-08-12 17:12:53 -07:00
resolver [maven-release-plugin] prepare for next development iteration 2016-07-27 13:29:56 +02:00
resolver-dns Disable IPv6 address lookups when -Djava.net.preferIPv4Stack=true 2016-08-10 11:10:34 +02:00
tarball [maven-release-plugin] prepare for next development iteration 2016-07-27 13:29:56 +02:00
testsuite [maven-release-plugin] prepare for next development iteration 2016-07-27 13:29:56 +02:00
testsuite-osgi [maven-release-plugin] prepare for next development iteration 2016-07-27 13:29:56 +02:00
transport Guard against re-entrance in PendingWriteQueue.removeAndWriteAll() 2016-08-18 07:13:19 +02:00
transport-native-epoll removed unnecessary static holders 2016-08-03 06:17:31 -07:00
transport-rxtx removed unnecessary static holders 2016-08-03 06:17:31 -07:00
transport-sctp [#4204] Broken support of SCTP_INIT_MAXSTREAMS in *SctpServerChannel 2016-08-05 18:55:47 +02:00
transport-udt removed unnecessary static holders 2016-08-03 06:17:31 -07:00
.fbprefs Updated Find Bugs configuration 2009-03-04 10:33:09 +00:00
.gitignore Use shaded dependency on JCTools instead of copy and paste 2016-06-10 13:19:45 +02: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 Upgrade netty-tcnative 2016-08-11 11:08:08 +02:00
README.md Updating Branches to look section to match the current branching structure of the project 2016-03-10 22:08:01 +01:00
run-example.sh Add an example client for codec-redis 2016-04-23 11:18:12 -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

Development of all 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.