Go to file
Scott Mitchell ee7027288e
ByteToMessageDecoder Cumulator improments (#9877)
Motivation:
ByteToMessageDecoder's default MERGE_CUMULATOR will allocate a new buffer and
copy if the refCnt() of the cumulation is > 1. However this is overly
conservative because we maybe able to avoid allocate/copy if the current
cumulation can accommodate the input buffer without a reallocation. Also when the
reallocation and copy does occur the new buffer is sized just large enough to
accommodate the current the current amount of data. If some data remains in the
cumulation after decode this will require a new allocation/copy when more data
arrives.

Modifications:
- Use maxFastWritableBytes to avoid allocation/copy if the current buffer can
  accommodate the input data without a reallocation operation.
- Use ByteBufAllocator#calculateNewCapacity(..) to get the size of the buffer
  when a reallocation/copy operation is necessary.

Result:
ByteToMessageDecoder MERGE_CUMULATOR won't allocate/copy if the cumulation
buffer can accommodate data without a reallocation, and when a reallocation
occurs we are more likely to leave additional space for future data in an effort
to reduce overall reallocations.
2019-12-13 09:48:25 -08:00
.github Change the netty.io homepage scheme(http -> https) (#9344) 2019-07-09 21:09:42 +02:00
.mvn Use latest maven release (#9820) 2019-11-27 14:45:28 +01:00
all Introduce MacOSDnsServerAddressStreamProvider which correctly detect all nameserver configuration on MacOS (#9161) 2019-10-28 15:02:45 +01:00
bom [maven-release-plugin] prepare for next development iteration 2019-10-24 12:57:00 +00:00
buffer Add unit test for leak aware CompositeByteBuf that proves that there is no NPE (#9875) 2019-12-12 16:18:27 +01:00
codec ByteToMessageDecoder Cumulator improments (#9877) 2019-12-13 09:48:25 -08:00
codec-dns [maven-release-plugin] prepare for next development iteration 2019-10-24 12:57:00 +00:00
codec-haproxy Uniform null pointer check. (#9840) 2019-12-09 09:47:35 +01:00
codec-http Verify we do not receive multiple content-length headers or a content-length and transfer-encoding: chunked header when using HTTP/1.1 (#9865) 2019-12-13 08:53:19 +01:00
codec-http2 Change DefaultByteBufHolder.equals() to treat instances of different classes as not equal (#9855) 2019-12-10 11:29:44 +01:00
codec-memcache Uniform null pointer check. (#9840) 2019-12-09 09:47:35 +01:00
codec-mqtt Uniform null pointer check. (#9840) 2019-12-09 09:47:35 +01:00
codec-redis Change DefaultByteBufHolder.equals() to treat instances of different classes as not equal (#9855) 2019-12-10 11:29:44 +01:00
codec-smtp [maven-release-plugin] prepare for next development iteration 2019-10-24 12:57:00 +00:00
codec-socks Uniform null pointer check. (#9840) 2019-12-09 09:47:35 +01:00
codec-stomp Uniform null pointer check. (#9840) 2019-12-09 09:47:35 +01:00
codec-xml [maven-release-plugin] prepare for next development iteration 2019-10-24 12:57:00 +00:00
common Ensure scheduled tasks are executed before shutdown (#9858) 2019-12-11 10:48:38 +01:00
dev-tools [maven-release-plugin] prepare for next development iteration 2019-10-24 12:57:00 +00:00
docker Upgrade various JDK flavors / version in our docker-compose files (#9737) 2019-10-31 12:16:24 +01:00
example Uniform null pointer check. (#9840) 2019-12-09 09:47:35 +01:00
handler Uniform null pointer check. (#9840) 2019-12-09 09:47:35 +01:00
handler-proxy Uniform null pointer check. (#9840) 2019-12-09 09:47:35 +01:00
license Introduce MacOSDnsServerAddressStreamProvider which correctly detect all nameserver configuration on MacOS (#9161) 2019-10-28 15:02:45 +01:00
microbench Uniform null pointer check. (#9840) 2019-12-09 09:47:35 +01:00
resolver Uniform null pointer check. (#9840) 2019-12-09 09:47:35 +01:00
resolver-dns Uniform null pointer check. (#9840) 2019-12-09 09:47:35 +01:00
resolver-dns-native-macos Fix version for resolver-dns-native-macos introduced by 939e928312 2019-10-28 15:09:30 +01:00
tarball Introduce MacOSDnsServerAddressStreamProvider which correctly detect all nameserver configuration on MacOS (#9161) 2019-10-28 15:02:45 +01:00
testsuite Uniform null pointer check. (#9840) 2019-12-09 09:47:35 +01:00
testsuite-autobahn [maven-release-plugin] prepare for next development iteration 2019-10-24 12:57:00 +00:00
testsuite-http2 Validate pseudo and conditional HTTP/2 headers (#8619) 2019-10-27 16:13:01 +01:00
testsuite-native-image [maven-release-plugin] prepare for next development iteration 2019-10-24 12:57:00 +00:00
testsuite-osgi [maven-release-plugin] prepare for next development iteration 2019-10-24 12:57:00 +00:00
testsuite-shading [maven-release-plugin] prepare for next development iteration 2019-10-24 12:57:00 +00:00
transport Channel Pool LocalAddress initialization and cleanup (#9879) 2019-12-13 13:45:22 +01:00
transport-blockhound-tests Test that NettyBlockHoundIntegration can be loaded with ServiceLoader (#9743) 2019-11-01 07:07:33 +01:00
transport-native-epoll Revert "Epoll: Avoid redundant EPOLL_CTL_MOD calls (#9397) (#9583)" 2019-12-11 14:53:37 +01:00
transport-native-kqueue Uniform null pointer check. (#9840) 2019-12-09 09:47:35 +01:00
transport-native-unix-common Uniform null pointer check. (#9840) 2019-12-09 09:47:35 +01:00
transport-native-unix-common-tests [maven-release-plugin] prepare for next development iteration 2019-10-24 12:57:00 +00:00
transport-rxtx [maven-release-plugin] prepare for next development iteration 2019-10-24 12:57:00 +00:00
transport-sctp Uniform null pointer check. (#9840) 2019-12-09 09:47:35 +01:00
transport-udt [maven-release-plugin] prepare for next development iteration 2019-10-24 12:57:00 +00:00
.fbprefs
.gitattributes Include mvn wrapper to make setup of development env easier 2018-01-26 08:13:17 +01:00
.gitignore Add vscode specific files / directory to .gitignore (#9652) 2019-10-10 09:35:08 +04:00
CONTRIBUTING.md Change the netty.io homepage scheme(http -> https) (#9344) 2019-07-09 21:09:42 +02:00
LICENSE.txt
mvnw Include mvn wrapper to make setup of development env easier 2018-01-26 08:13:17 +01:00
mvnw.cmd Include mvn wrapper to make setup of development env easier 2018-01-26 08:13:17 +01:00
NOTICE.txt Introduce MacOSDnsServerAddressStreamProvider which correctly detect all nameserver configuration on MacOS (#9161) 2019-10-28 15:02:45 +01:00
pom.xml Include JCTools sources for shaded classes in the sources jar (#9838) 2019-12-05 09:10:32 +01:00
README.md Change the netty.io homepage scheme(http -> https) (#9344) 2019-07-09 21:09:42 +02:00
run-example.sh Add UptimeServer and adjust UptimeClient's code style. 2017-04-28 07:41:07 +02: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.

Usage with JDK 9

Netty can be used in modular JDK9 applications as a collection of automatic modules. The module names follow the reverse-DNS style, and are derived from subproject names rather than root packages due to historical reasons. They are listed below:

  • io.netty.all
  • io.netty.buffer
  • io.netty.codec
  • io.netty.codec.dns
  • io.netty.codec.haproxy
  • io.netty.codec.http
  • io.netty.codec.http2
  • io.netty.codec.memcache
  • io.netty.codec.mqtt
  • io.netty.codec.redis
  • io.netty.codec.smtp
  • io.netty.codec.socks
  • io.netty.codec.stomp
  • io.netty.codec.xml
  • io.netty.common
  • io.netty.handler
  • io.netty.handler.proxy
  • io.netty.resolver
  • io.netty.resolver.dns
  • io.netty.transport
  • io.netty.transport.epoll (native omitted - reserved keyword in Java)
  • io.netty.transport.kqueue (native omitted - reserved keyword in Java)
  • io.netty.transport.unix.common (native omitted - reserved keyword in Java)
  • io.netty.transport.rxtx
  • io.netty.transport.sctp
  • io.netty.transport.udt

Automatic modules do not provide any means to declare dependencies, so you need to list each used module separately in your module-info file.