2018-08-01 22:22:09 -04:00
|
|
|
# velocity-natives
|
|
|
|
|
|
|
|
This directory contains native acceleration code for Velocity, along with
|
|
|
|
traditional Java fallbacks.
|
|
|
|
|
|
|
|
## Compression
|
|
|
|
|
2020-06-23 09:57:04 -04:00
|
|
|
* **Supported platforms**: Linux x86_64 and aarch64, with Java 11 `ByteBuffer` API support as a fallback.
|
|
|
|
Compiled on CentOS 7.
|
2018-08-01 22:22:09 -04:00
|
|
|
* **Rationale**: Using a native zlib wrapper, we can avoid multiple trips into Java just to copy memory around.
|
|
|
|
|
|
|
|
## Encryption
|
|
|
|
|
2020-06-23 09:57:04 -04:00
|
|
|
* **Supported platforms**: Linux x86_64 (OpenSSL 1.0.x and OpenSSL 1.1.x) and aarch64 (OpenSSL 1.1.x only)
|
2018-08-04 23:46:41 -04:00
|
|
|
* **Rationale**: Using a C library for encryption means we can limit memory copies. Prior to Java 7, this was the only
|
|
|
|
way to use AES-NI extensions on modern processors, but this is less important since JDK 8 has native support.
|
2020-06-23 09:57:04 -04:00
|
|
|
* OpenSSL is not included in Velocity. Every distribution provides it now. To deal with ABI incompatibilities,
|
|
|
|
the native library (which only calls into OpenSSL and contains no cryptographic code) are available for
|
2022-08-28 23:24:56 +02:00
|
|
|
CentOS 7 (OpenSSL 1.0.0-based), Debian 9 (OpenSSL 1.1.0-based) and Debian Bookworm (OpenSSL 3.0.0-based)
|
|
|
|
to provide the widest, most reasonable compatibility with most modern distributions.
|
2018-08-01 22:22:09 -04:00
|
|
|
|
|
|
|
## OS support
|
|
|
|
|
2020-06-23 09:57:04 -04:00
|
|
|
The natives intend to have the widest possible range of compatibility with modern Linux distributions
|
|
|
|
(defined as those being released in or after 2014).
|
|
|
|
|
|
|
|
In theory, these libraries can be compiled for any Unix-like system (in the past, we supported macOS),
|
|
|
|
but interest in other systems is minimal at best, thus we focus on Linux x86_64 and aarch64 as they
|
|
|
|
are commonly used platforms.
|
|
|
|
|
2020-06-23 10:00:08 -04:00
|
|
|
Alpine Linux support is on a "best-effort" basis only. Using `apk add libc6-compat` may enable native support.
|