Go to file
Chris Vest c41d46111d
Create bespoke long/long hashmap and long-valued priority queue for PoolChunk (#10826)
Motivation:
The uncached access to PoolChunk can be made faster, and avoid allocating boxed Longs, if we have a primitive hash map and priority queue implementation for it.

Modification:
Add bespoke primitive implementations of a hash map and a priority queue for PoolChunk.
Remove all the long-boxing caused by the previous implementation.
The hashmap is a linear probing map with a fairly short probe that keeps the search within a couple of cache lines.
The priority queue is the same binary heap algorithm that's described in Algorithms by Sedgewick and Wayne.
The implementation avoids the Long boxing by relying on a long[] array.
This makes the internal-remove method faster, which is an important operation in PoolChunk.

Result:
Roughly 13% performance uplift in buffer allocations that miss cache.
2020-11-29 11:29:46 +01:00
.github Smaller output in codeql build (#10787) 2020-11-09 15:32:18 +01:00
.mvn Use latest maven release (#9820) 2019-11-27 14:45:28 +01:00
all [maven-release-plugin] prepare for next development iteration 2020-11-11 05:47:51 +00:00
bom [maven-release-plugin] prepare for next development iteration 2020-11-11 05:47:51 +00:00
buffer Create bespoke long/long hashmap and long-valued priority queue for PoolChunk (#10826) 2020-11-29 11:29:46 +01:00
codec Fix NPE in ByteToMessageDecoder if the user removes the handler while channelInputClosed(...) is processing the buffer. (#10817) 2020-11-24 14:08:32 +01:00
codec-dns [maven-release-plugin] prepare for next development iteration 2020-11-11 05:47:51 +00:00
codec-haproxy [maven-release-plugin] prepare for next development iteration 2020-11-11 05:47:51 +00:00
codec-http Override Sec-WebSocket-Protocol websocket handshake response header after custom headers to avoid duplication (#10793) 2020-11-19 09:49:44 +01:00
codec-http2 Fix comment typo DelegatingDecompressorFrameListener (#10789) 2020-11-16 09:03:37 +01:00
codec-memcache [maven-release-plugin] prepare for next development iteration 2020-11-11 05:47:51 +00:00
codec-mqtt [maven-release-plugin] prepare for next development iteration 2020-11-11 05:47:51 +00:00
codec-redis [maven-release-plugin] prepare for next development iteration 2020-11-11 05:47:51 +00:00
codec-smtp [maven-release-plugin] prepare for next development iteration 2020-11-11 05:47:51 +00:00
codec-socks [maven-release-plugin] prepare for next development iteration 2020-11-11 05:47:51 +00:00
codec-stomp Add ABORT and COMMIT STOMP commands to the StompCommand enum (#10790) 2020-11-19 14:23:37 +01:00
codec-xml [maven-release-plugin] prepare for next development iteration 2020-11-11 05:47:51 +00:00
common Allow blocking calls inside SingleThreadEventExecutor.addTask (#10811) 2020-11-23 19:20:18 +01:00
dev-tools [maven-release-plugin] prepare for next development iteration 2020-11-11 05:47:51 +00:00
docker Update to latest java 8/11/15 versions (#10774) 2020-11-04 10:39:55 +01:00
example Let object serialisation exceptions propagate in the Object Echo example (#10807) 2020-11-19 08:10:17 +01:00
handler OpenSsl.memoryAddress(...) should use internalNioBuffer(...) if it can't access the memoryAddress (#10818) 2020-11-25 10:31:58 +01:00
handler-proxy [maven-release-plugin] prepare for next development iteration 2020-11-11 05:47:51 +00:00
license Enable nohttp check during the build (#10708) 2020-10-23 14:44:18 +02:00
microbench Fix caching for normal allocations (#10825) 2020-11-25 15:05:30 +01:00
resolver [maven-release-plugin] prepare for next development iteration 2020-11-11 05:47:51 +00:00
resolver-dns Don't use the cname cache when using DnsRecordResolveContext (#10808) 2020-11-26 15:34:56 +01:00
resolver-dns-native-macos [maven-release-plugin] prepare for next development iteration 2020-11-11 05:47:51 +00:00
tarball [maven-release-plugin] prepare for next development iteration 2020-11-11 05:47:51 +00:00
testsuite [maven-release-plugin] prepare for next development iteration 2020-11-11 05:47:51 +00:00
testsuite-autobahn [maven-release-plugin] prepare for next development iteration 2020-11-11 05:47:51 +00:00
testsuite-http2 [maven-release-plugin] prepare for next development iteration 2020-11-11 05:47:51 +00:00
testsuite-native-image [maven-release-plugin] prepare for next development iteration 2020-11-11 05:47:51 +00:00
testsuite-native-image-client [maven-release-plugin] prepare for next development iteration 2020-11-11 05:47:51 +00:00
testsuite-osgi [maven-release-plugin] prepare for next development iteration 2020-11-11 05:47:51 +00:00
testsuite-shading [maven-release-plugin] prepare for next development iteration 2020-11-11 05:47:51 +00:00
transport [maven-release-plugin] prepare for next development iteration 2020-11-11 05:47:51 +00:00
transport-blockhound-tests Allow blocking calls inside SingleThreadEventExecutor.addTask (#10811) 2020-11-23 19:20:18 +01:00
transport-native-epoll IovArray should support when there is no unsafe present (#10814) 2020-11-23 14:03:32 +01:00
transport-native-kqueue IovArray should support when there is no unsafe present (#10814) 2020-11-23 14:03:32 +01:00
transport-native-unix-common IovArray should support when there is no unsafe present (#10814) 2020-11-23 14:03:32 +01:00
transport-native-unix-common-tests IovArray should support when there is no unsafe present (#10814) 2020-11-23 14:03:32 +01:00
transport-rxtx [maven-release-plugin] prepare for next development iteration 2020-11-11 05:47:51 +00:00
transport-sctp [maven-release-plugin] prepare for next development iteration 2020-11-11 05:47:51 +00:00
transport-udt [maven-release-plugin] prepare for next development iteration 2020-11-11 05:47:51 +00:00
.fbprefs Updated Find Bugs configuration 2009-03-04 10:33:09 +00:00
.gitattributes Include mvn wrapper to make setup of development env easier 2018-01-26 08:13:17 +01:00
.gitignore Ignore .shelf/ folder generated by IntelliJ IDEA (#10445) 2020-08-03 07:51:53 +02:00
.lgtm.yml Enables lgtm.com to process this project and create a CodeQL database 2020-01-17 11:05:53 +01:00
CONTRIBUTING.md Change the netty.io homepage scheme(http -> https) (#9344) 2019-07-09 21:09:42 +02:00
LICENSE.txt Enable nohttp check during the build (#10708) 2020-10-23 14:44:18 +02:00
mvnw Enable nohttp check during the build (#10708) 2020-10-23 14:44:18 +02:00
mvnw.cmd Enable nohttp check during the build (#10708) 2020-10-23 14:44:18 +02:00
nohttp-checkstyle-suppressions.xml Use http in xmlns URIs to make maven release plugin happy again (#10788) 2020-11-10 10:22:35 +01:00
nohttp-checkstyle.xml Enable nohttp check during the build (#10708) 2020-10-23 14:44:18 +02:00
NOTICE.txt Fix License type of dnsinfo (#10773) 2020-11-04 10:40:43 +01:00
pom.xml [maven-release-plugin] prepare for next development iteration 2020-11-11 05:47:51 +00:00
README.md Enable nohttp check during the build (#10708) 2020-10-23 14:44:18 +02:00
run-example.sh Add DNS client examples for run-example.sh (#10283) 2020-05-14 12:10:32 +02:00
SECURITY.md Added a security policy (#10692) 2020-10-15 20:39:37 +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.