diff --git a/README.md b/README.md index 6d3a703..626afe9 100644 --- a/README.md +++ b/README.md @@ -322,7 +322,7 @@ _Libraries and frameworks for writing distributed and fault-tolerant application - [Axon](https://axoniq.io) - Framework for creating CQRS applications. - [Dropwizard Circuit Breaker](https://github.com/mtakaki/dropwizard-circuitbreaker) - Circuit breaker design pattern for Dropwizard. (GPL-2.0-only) - [Failsafe](https://github.com/jhalterman/failsafe) - Simple failure handling with retries and circuit breakers. -- [Hazelcast](https://hazelcast.org/) - Highly scalable in-memory datagrid with a free open-source version. +- [Hazelcast](https://github.com/hazelcast/hazelcast) - Highly scalable in-memory datagrid with a free open-source version. - [JGroups](http://www.jgroups.org) - Toolkit for reliable messaging and cluster creation. - [Orbit](http://www.orbit.cloud) - Virtual actors; adds another level of abstraction to traditional actors. - [Quasar](http://docs.paralleluniverse.co/quasar/) - Lightweight threads and actors for the JVM. @@ -386,21 +386,21 @@ _Formal-methods tools: proof assistants, model checking, symbolic execution, etc _Libraries that facilitate functional programming._ -- [cyclops-react](https://github.com/aol/cyclops-react) - Monad and stream utilities, comprehensions, pattern matching, functional extensions for all JDK collections, future streams, trampolines and much more. +- [Cyclops](https://github.com/aol/cyclops) - Monad and stream utilities, comprehensions, pattern matching, functional extensions for all JDK collections, future streams, trampolines and much more. - [derive4j](https://github.com/derive4j/derive4j) - Java 8 annotation processor and framework for deriving algebraic data types constructors, pattern-matching and morphisms. (GPL-3.0-only) - [Fugue](https://bitbucket.org/atlassian/fugue) - Functional extensions to Guava. - [Functional Java](http://www.functionaljava.org) - Implements numerous basic and advanced programming abstractions that assist composition-oriented development. - [jOOλ](https://github.com/jOOQ/jOOL) - Extension to Java 8 that aims to fix gaps in lambda by providing numerous missing types and a rich set of sequential Stream API additions. - [protonpack](https://github.com/poetix/protonpack) - Collection of stream utilities. - [StreamEx](https://github.com/amaembo/streamex) - Enhances Java 8 Streams. -- [Vavr](http://www.vavr.io) - Functional component library that provides persistent data types and functional control structures. +- [Vavr](https://www.vavr.io) - Functional component library that provides persistent data types and functional control structures. ### Game Development _Frameworks that support the development of games._ -- [FXGL](https://almasb.github.io/FXGL) - JavaFX Game Development Framework. -- [jMonkeyEngine](http://jmonkeyengine.org) - Game engine for modern 3D development. +- [FXGL](https://almasb.github.io/FXGL/) - JavaFX Game Development Framework. +- [jMonkeyEngine](https://jmonkeyengine.org) - Game engine for modern 3D development. - [libGDX](https://libgdx.badlogicgames.com) - All-round cross-platform, high-level framework. - [LWJGL](https://www.lwjgl.org) - Robust framework that abstracts libraries like OpenGL/CL/AL. @@ -414,7 +414,7 @@ _Libraries for working with geospatial data and algorithms._ - [GeoTools](https://geotools.org) - Library that provides tools for geospatial data. (LGPL-2.1-only) - [GraphHopper](https://github.com/graphhopper/graphhopper) - Road-routing engine. Used as a Java library or standalone web service. - [H2GIS](http://www.h2gis.org) - Spatial extension of the H2 database. (LGPL-3.0-only) -- [Jgeohash](https://astrapi69.github.io/jgeohash) - Library for using the GeoHash algorithm. +- [Jgeohash](https://astrapi69.github.io/jgeohash/) - Library for using the GeoHash algorithm. - [Mapsforge](https://github.com/mapsforge/mapsforge) - Map rendering based on OpenStreetMap data. (LGPL-3.0-only) - [Spatial4j](https://github.com/locationtech/spatial4j) - General-purpose spatial/geospatial library. @@ -423,15 +423,15 @@ _Libraries for working with geospatial data and algorithms._ _Libraries to create modern graphical user interfaces._ - [JavaFX](https://wiki.openjdk.java.net/display/OpenJFX/Main) - Successor of Swing. -- [Scene Builder](https://gluonhq.com/open-source/scene-builder) - Visual layout tool for JavaFX applications. -- [SWT](https://www.eclipse.org/swt) - Graphical widget toolkit. +- [Scene Builder](https://gluonhq.com/products/scene-builder/) - Visual layout tool for JavaFX applications. +- [SWT](https://www.eclipse.org/swt/) - Graphical widget toolkit. ### High Performance _Everything about high-performance computation, from collections to specific libraries._ - [Agrona](https://github.com/real-logic/Agrona) - Data structures and utility methods that are common in high-performance applications. -- [Disruptor](https://lmax-exchange.github.io/disruptor) - Inter-thread messaging library. +- [Disruptor](https://lmax-exchange.github.io/disruptor/) - Inter-thread messaging library. - [Eclipse Collections](https://github.com/eclipse/eclipse-collections) - Collections framework inspired by Smalltalk. - [fastutil](http://fastutil.di.unimi.it) - Fast and compact type-specific collections. - [HPPC](https://labs.carrotsearch.com/hppc.html) - Primitive collections. @@ -443,11 +443,11 @@ _Everything about high-performance computation, from collections to specific lib _Libraries that assist with creating HTTP requests and/or binding responses._ - [Async Http Client](https://github.com/AsyncHttpClient/async-http-client) - Asynchronous HTTP and WebSocket client library. -- [Feign](https://github.com/Netflix/feign) - HTTP client binder inspired by Retrofit, JAXRS-2.0, and WebSocket. -- [OkHttp](https://square.github.io/okhttp) - HTTP and SPDY client. +- [Feign](https://github.com/OpenFeign/feign) - HTTP client binder inspired by Retrofit, JAXRS-2.0, and WebSocket. +- [OkHttp](https://square.github.io/okhttp/) - HTTP and SPDY client. - [Play WS](https://github.com/playframework/play-ws) - Typesafe client with reactive streams and caching. -- [restQL-core-java](https://github.com/B2W-BIT/restQL-java) - Microservice query language that fetches information from multiple services. -- [Retrofit](https://square.github.io/retrofit) - Typesafe REST client. +- [restQL-java](https://github.com/b2wdigital/restQL-java) - Microservice query language that fetches information from multiple services. +- [Retrofit](https://square.github.io/retrofit/) - Typesafe REST client. - [Ribbon](https://github.com/Netflix/ribbon) - Client-side IPC library that is battle-tested in cloud. - [Riptide](https://github.com/zalando/riptide) - Client-side response routing for Spring's RestTemplate. - [unirest-java](https://github.com/Kong/unirest-java) - Simplified, lightweight HTTP client library. @@ -464,7 +464,7 @@ _Libraries that handle serialization to hypermedia types._ _Integrated development environments that try to simplify several aspects of development._ - [Eclipse](https://www.eclipse.org) - Established open-source project with support for lots of plugins and languages. -- [IntelliJ IDEA ![c]](https://www.jetbrains.com/idea) - Supports many JVM languages and provides good options for Android development. The commercial edition targets the enterprise sector. +- [IntelliJ IDEA ![c]](https://www.jetbrains.com/idea/) - Supports many JVM languages and provides good options for Android development. The commercial edition targets the enterprise sector. - [jGRASP](https://www.jgrasp.org) - Created to provide software visualizations that work in conjunction with the debugger such as Control Structure Diagrams, UML class diagrams and Object Viewer. - [NetBeans](https://netbeans.apache.org) - Provides integration for several Java SE and EE features, from database access to HTML5. - [Visual Studio Code](https://code.visualstudio.com/docs/languages/java) - Provides Java support for lightweight projects with a simple, modern workflow by using extensions from the internal marketplace. @@ -473,7 +473,7 @@ _Integrated development environments that try to simplify several aspects of dev _Libraries that assist with the creation, evaluation or manipulation of graphical images._ -- [Imgscalr](https://github.com/thebuzzmedia/imgscalr) - Simple, efficient and hardware-accelerated image-scaling library implemented in pure Java 2D. +- [Imgscalr](https://github.com/rkalla/imgscalr) - Simple, efficient and hardware-accelerated image-scaling library implemented in pure Java 2D. - [Tess4J](https://github.com/nguyenq/tess4j) - JNA wrapper for Tesseract OCR API. - [Thumbnailator](https://github.com/coobird/thumbnailator) - High-quality thumbnail generation library. - [TwelveMonkeys](https://github.com/haraldk/TwelveMonkeys) - Collection of plugins that extend the number of supported image file formats. @@ -486,7 +486,7 @@ _Libraries that help make the Java introspection and reflection API easier and f - [ClassGraph](https://github.com/classgraph/classgraph) - ClassGraph (formerly FastClasspathScanner) is an uber-fast, ultra-lightweight, parallelized classpath scanner and module scanner for Java, Scala, Kotlin and other JVM languages. - [jOOR](https://github.com/jOOQ/jOOR) - jOOR stands for jOOR Object Oriented Reflection. It is a simple wrapper for the java.lang.reflect package. -- [Mirror](http://projetos.vidageek.net/mirror/mirror) - Mirror was created to bring light to a simple problem, usually named ReflectionUtil, which is on almost all projects that rely on reflection to do advanced tasks. +- [Mirror](http://projetos.vidageek.net/mirror/mirror/) - Mirror was created to bring light to a simple problem, usually named ReflectionUtil, which is on almost all projects that rely on reflection to do advanced tasks. - [Objenesis](http://objenesis.org) - Allows dynamic instantiation without default constructor, e.g. constructors which have required arguments, side effects or throw exceptions. - [ReflectASM](https://github.com/EsotericSoftware/reflectasm) - ReflectASM is a very small Java library that provides high performance reflection by using code generation. - [Reflections](https://github.com/ronmamo/reflections) - Reflections scans your classpath, indexes the metadata, allows you to query it on runtime and may save and collect that information for many modules within your project. @@ -505,7 +505,7 @@ _Libraries for scheduling background jobs._ _Libraries for serializing and deserializing JSON to and from Java objects._ - [DSL-JSON](https://github.com/ngs-doo/dsl-json) - JSON library with advanced compile time databinding. -- [Genson](https://owlike.github.io/genson) - Powerful and easy-to-use Java-to-JSON conversion library. +- [Genson](http://genson.io) - Powerful and easy-to-use Java-to-JSON conversion library. - [Gson](https://github.com/google/gson) - Serializes objects to JSON and vice versa. Good performance with on-the-fly usage. - [HikariJSON](https://github.com/brettwooldridge/HikariJSON) - High-performance JSON parser, 2x faster than Jackson. - [jackson-modules-java8](https://github.com/FasterXML/jackson-modules-java8) - Set of Jackson modules for Java 8 datatypes and features. @@ -515,10 +515,10 @@ _Libraries for serializing and deserializing JSON to and from Java objects._ - [jsoniter](http://jsoniter.com) - Fast and flexible library with iterator and lazy parsing API. - [LoganSquare](https://github.com/bluelinelabs/LoganSquare) - JSON parsing and serializing library based on Jackson's streaming API. Outperforms GSON & Jackson's library. - [Moshi](https://github.com/square/moshi) - Modern JSON library, less opinionated and uses built-in types like List and Map. -- [Yasson](https://github.com/eclipse/yasson) - Binding layer between classes and JSON documents similar to JAXB. +- [Yasson](https://github.com/eclipse-ee4j/yasson) - Binding layer between classes and JSON documents similar to JAXB. - [fastjson](https://github.com/alibaba/fastjson) - Very fast processor with no additional dependencies and full data binding. - [Jolt](https://github.com/bazaarvoice/jolt) - JSON to JSON transformation tool. -- [JsonPath](https://github.com/jayway/JsonPath) - Extract data from JSON using XPATH-like syntax. +- [JsonPath](https://github.com/json-path/JsonPath) - Extract data from JSON using XPATH-like syntax. - [JsonSurfer](https://github.com/jsurfer/JsonSurfer) - Streaming JsonPath processor dedicated to processing big and complicated JSON data. ### JVM and JDK @@ -527,30 +527,30 @@ _Current implementations of the JVM/JDK._ - [Adopt Open JDK](https://adoptopenjdk.net) - Community-driven OpenJDK builds, including both HotSpot and OpenJ9. - [Avian](https://github.com/ReadyTalk/avian) - JVM with JIT, AOT modes and iOS port. -- [Corretto](https://aws.amazon.com/corretto) - No-cost, multiplatform, production-ready distribution of OpenJDK by Amazon. (GPL-2.0-only WITH Classpath-exception-2.0) +- [Corretto](https://aws.amazon.com/corretto/) - No-cost, multiplatform, production-ready distribution of OpenJDK by Amazon. (GPL-2.0-only WITH Classpath-exception-2.0) - [Graal](https://github.com/oracle/graal) - Polyglot embeddable JVM. (GPL-2.0-only WITH Classpath-exception-2.0) -- [Liberica JDK](https://www.bell-sw.com/java.html) - Built from OpenJDK, thoroughly tested and passed the JCK. (GPL-2.0-only WITH Classpath-exception-2.0) +- [Liberica JDK](https://bell-sw.com) - Built from OpenJDK, thoroughly tested and passed the JCK. (GPL-2.0-only WITH Classpath-exception-2.0) - [OpenJ9](https://github.com/eclipse/openj9) - High performance, enterprise-calibre, flexibly licensed, openly-governed cross-platform JVM extending and augmenting the runtime technology components from the Eclipse OMR and OpenJDK project. - [Open JDK](https://openjdk.java.net) - Open JDK community home. (GPL-2.0-only WITH Classpath-exception-2.0) - [ParparVM](https://github.com/codenameone/CodenameOne/tree/master/vm) - VM with non-blocking, concurrent GC for iOS. (GPL-2.0-only WITH Classpath-exception-2.0) - [RedHat Open JDK](https://developers.redhat.com/products/openjdk/overview) - RedHat's OpenJDK distribution. (GPL-2.0-only WITH Classpath-exception-2.0) -- [SAP Machine](https://sap.github.io/SapMachine) - SAP's no-cost, rigorously tested and JCK-verified OpenJDK friendly fork. (GPL-2.0-only WITH Classpath-exception-2.0) -- [Zulu](https://www.azul.com/downloads/zulu) - OpenJDK builds for Windows, Linux, and macOS. (GPL-2.0-only WITH Classpath-exception-2.0) +- [SAP Machine](https://sap.github.io/SapMachine/) - SAP's no-cost, rigorously tested and JCK-verified OpenJDK friendly fork. (GPL-2.0-only WITH Classpath-exception-2.0) +- [Zulu](https://www.azul.com/products/zulu-community/) - OpenJDK builds for Windows, Linux, and macOS. (GPL-2.0-only WITH Classpath-exception-2.0) ### Logging _Libraries that log the behavior of an application._ -- [Apache Log4j 2](https://logging.apache.org/log4j) - Complete rewrite with a powerful plugin and configuration architecture. +- [Apache Log4j 2](https://logging.apache.org/log4j/) - Complete rewrite with a powerful plugin and configuration architecture. - [Graylog](https://www.graylog.org) - Open-source aggregator suited for extended role and permission management. (GPL-3.0-only) -- [Kibana](https://www.elastic.co/products/kibana) - Analyzes and visualizes log files. Some features require payment. -- [Logback](https://logback.qos.ch) - Robust logging library with interesting configuration options via Groovy. +- [Kibana](https://www.elastic.co/kibana) - Analyzes and visualizes log files. Some features require payment. +- [Logback](http://logback.qos.ch) - Robust logging library with interesting configuration options via Groovy. - [Logbook](https://github.com/zalando/logbook) - Extensible, open-source library for HTTP request and response logging. -- [Logstash](https://www.elastic.co/products/logstash) - Tool for managing log files. +- [Logstash](https://www.elastic.co /logstash) - Tool for managing log files. - [p6spy](https://github.com/p6spy/p6spy) - Enables logging for all JDBC transactions without changes to the code. - [SLF4J](http://www.slf4j.org) - Abstraction layer/simple logging facade. -- [tinylog](http://www.tinylog.org) - Lightweight logging framework with static logger class. -- [Tracer](https://github.com/zalando/tracer) - Call tracing and log correlation in distributed systems. +- [tinylog](https://tinylog.org/v2/) - Lightweight logging framework with static logger class. +- [OpenTracing Toolbox](https://github.com/zalando/opentracing-toolbox) - Collection of libraries that build on top of OpenTracing and provide extensions and plugins to existing instrumentations. ### Machine Learning @@ -566,8 +566,8 @@ _Tools that provide specific statistical algorithms for learning from data._ - [JSAT](https://github.com/EdwardRaff/JSAT) - Algorithms for pre-processing, classification, regression, and clustering with support for multi-threaded execution. (GPL-3.0-only) - [Oryx 2](https://github.com/OryxProject/oryx) - Framework for building real-time, large-scale machine learning applications. Includes end-to-end applications for collaborative filtering, classification, regression, and clustering. - [Smile](https://github.com/haifengl/smile) - Statistical Machine Intelligence and Learning Engine provides a set of machine learning algorithms and a visualization library. -- [Synapses](https://mrdimosthenis.github.io/Synapses) - Lightweight library for neural networks. -- [Weka](https://www.cs.waikato.ac.nz/ml/weka) - Collection of algorithms for data mining tasks ranging from pre-processing to visualization. (GPL-3.0-only) +- [Synapses](https://mrdimosthenis.github.io/Synapses/#synapses) - Lightweight library for neural networks. +- [Weka](https://www.cs.waikato.ac.nz/ml/weka/) - Collection of algorithms for data mining tasks ranging from pre-processing to visualization. (GPL-3.0-only) ### Messaging @@ -586,19 +586,19 @@ _Tools that help send messages between clients to ensure protocol independency._ - [Nakadi](https://github.com/zalando/nakadi) - Provides a RESTful API on top of Kafka. - [RabbitMQ Java client](https://github.com/rabbitmq/rabbitmq-java-client) - RabbitMQ client. - [Smack](https://github.com/igniterealtime/Smack) - Cross-platform XMPP client library. -- [NATS client](https://github.com/nats-io/java-nats) - NATS client. +- [NATS client](https://github.com/nats-io/nats.java) - NATS client. ### Microservice _Tools for creating and managing microservices._ -- [Apollo](https://spotify.github.io/apollo) - Libraries for writing composable microservices. +- [Apollo](https://spotify.github.io/apollo/) - Libraries for writing composable microservices. - [Armeria](https://github.com/line/armeria) - Asynchronous RPC/REST client/server library built on top of Java 8, Netty, HTTP/2, Thrift and gRPC. - [consul-api](https://github.com/Ecwid/consul-api) - Client for the Consul API: a distributed, highly available and datacenter-aware registry/discovery service. - [Eureka](https://github.com/Netflix/eureka) - REST-based service registry for resilient load balancing and failover. - [Helidon](https://helidon.io) - Two-style approach for writing microservices: Functional-reactive and as an implementation of MicroProfile. -- [Lagom](https://www.lightbend.com/lagom) - Framework for creating microservice-based systems. -- [Micronaut](http://micronaut.io) - Modern full-stack framework with focus on modularity, minimal memory footprint and startup time. +- [Lagom](https://www.lagomframework.com) - Framework for creating microservice-based systems. +- [Micronaut](https://micronaut.io) - Modern full-stack framework with focus on modularity, minimal memory footprint and startup time. - [Nacos](https://nacos.io) - Dynamic service discovery, configuration and service management platform for building cloud native applications. - [Quarkus](https://quarkus.io) - Kubernetes stack tailored for the HotSpot and Graal VM. @@ -615,19 +615,19 @@ _Everything else._ - [J2ObjC](https://github.com/google/j2objc) - Java-to-Objective-C translator for porting Android libraries to iOS. - [JavaCV](https://github.com/bytedeco/javacv) - Java interface to OpenCV, FFmpeg, and more. - [JavaX](http://javax.botcompany.de) - Reinventing and extending Java with a focus on simplicity. (No explicit license) -- [JBake](http://jbake.org) - Static website generator. -- [JBot](https://github.com/ramswaroop/jbot) - Framework for building chatbots. (GPL-3.0-only) +- [JBake](https://jbake.org) - Static website generator. +- [JBot](https://github.com/rampatra/jbot) - Framework for building chatbots. (GPL-3.0-only) - [JCuda](http://jcuda.org) - JCuda offers Java bindings for CUDA and CUDA-related libraries. - [Jimfs](https://github.com/google/jimfs) - In-memory file system. -- [Joda-Money](http://www.joda.org/joda-money) - Basic currency and money classes and algorithms not provided by the JDK. +- [Joda-Money](https://www.joda.org/joda-money/) - Basic currency and money classes and algorithms not provided by the JDK. - [JPad](http://jpad.io) - Snippet runner. - [Maven Wrapper](https://github.com/takari/maven-wrapper) - Analogue of Gradle Wrapper for Maven, allows building projects without installing maven. - [Membrane Service Proxy](https://github.com/membrane/service-proxy) - Open-source, reverse-proxy framework. - [MinimalFTP](https://github.com/Guichaguri/MinimalFTP) - Lightweight, small and customizable FTP server. - [Modern Java - A Guide to Java 8](https://github.com/winterbe/java8-tutorial) - Popular Java 8 guide. -- [Modernizer](https://github.com/andrewgaul/modernizer-maven-plugin) - Detect uses of legacy Java APIs. +- [Modernizer](https://github.com/gaul/modernizer-maven-plugin) - Detect uses of legacy Java APIs. - [Multi-OS Engine](https://multi-os-engine.org) - Open-source, cross-platform engine to develop native mobile (iOS, Android, etc.) apps. -- [OctoLinker](https://github.com/OctoLinker/browser-extension) - Browser extension which allows to navigate through code on GitHub more efficiently. +- [OctoLinker](https://github.com/OctoLinker/OctoLinker) - Browser extension which allows to navigate through code on GitHub more efficiently. - [OpenRefine](http://openrefine.org) - Tool for working with messy data: cleaning, transforming, extending it with web services and linking it to databases. - [PipelinR](https://github.com/sizovs/pipelinr) - Small utility library for using handlers and commands with pipelines. - [Polyglot for Maven](https://github.com/takari/polyglot-maven) - Extensions for Maven 3.3.1+ that allows writing the POM model in dialects other than XML. @@ -644,21 +644,21 @@ _Tools that monitor applications in production._ - [Automon](https://github.com/stevensouza/automon) - Combines the power of AOP with monitoring and/or logging tools. - [LeakCanary](https://github.com/square/leakcanary) - Memory leak detection. -- [Failsafe Actuator](https://github.com/zalando-incubator/failsafe-actuator) - Out of the box monitoring of Failsafe Circuit Breaker in Spring-Boot environment. +- [Failsafe Actuator](https://github.com/zalando/failsafe-actuator) - Out of the box monitoring of Failsafe Circuit Breaker in Spring-Boot environment. - [Glowroot](https://glowroot.org) - Open-source Java APM. -- [inspectIT](http://www.inspectit.rocks) - Captures detailed run-time information via hooks that can be changed on the fly. It supports tracing over multiple systems via the OpenTracing API and can correlate the data with end user monitoring. +- [inspectIT](https://www.inspectit.rocks) - Captures detailed run-time information via hooks that can be changed on the fly. It supports tracing over multiple systems via the OpenTracing API and can correlate the data with end user monitoring. - [Instrumental ![c]](https://instrumentalapp.com) - Real-time Java application performance monitoring. A commercial service with free development accounts. - [JavaMelody](https://github.com/javamelody/javamelody) - Performance monitoring and profiling. - [Jaeger client](https://github.com/jaegertracing/jaeger-client-java) - Jaeger client. - [jmxtrans](https://github.com/jmxtrans/jmxtrans) - Connect to multiple JVMs and query them for their attributes via JMX. Its query language is based on JSON, which allows non-Java programmers to access the JVM attributes. Supports different output writes, including Graphite, Ganglia, and StatsD. - [Jolokia](https://jolokia.org) - JMX over REST. - [Kamon ![c]](https://kamon.io) - Tool for monitoring applications running on the JVM. -- [Metrics](http://metrics.dropwizard.io) - Expose metrics via JMX or HTTP and send them to a database. +- [Metrics](https://github.com/dropwizard/metrics) - Expose metrics via JMX or HTTP and send them to a database. - [Datadog ![c]](https://www.datadoghq.com) - Modern monitoring & analytics. - [nudge4j](https://github.com/lorenzoongithub/nudge4j) - Remote developer console from the browser for Java 8 via bytecode injection. - [Pinpoint](https://github.com/naver/pinpoint) - Open-source APM tool. - [Prometheus](https://prometheus.io) - Provides a multi-dimensional data model, DSL, autonomous server nodes and much more. -- [SPM ![c]](https://sematext.com/spm) - Performance monitor with distributing transaction tracing for JVM apps. +- [SPM ![c]](https://sematext.com/spm/) - Performance monitor with distributing transaction tracing for JVM apps. - [Stagemonitor](https://github.com/stagemonitor/stagemonitor) - Open-source performance monitoring and transaction tracing for JVM apps. - [Sysmon](https://github.com/palantir/Sysmon) - Lightweight platform monitoring tool for Java VMs. - [zipkin](https://zipkin.io) - Distributed tracing system which gathers timing data needed to troubleshoot latency problems in microservice architectures. @@ -680,7 +680,7 @@ _Libraries that specialize in processing text._ - [CoreNLP](https://nlp.stanford.edu/software/corenlp.shtml) - Provides a set of fundamental tools for tasks like tagging, named entity recognition, and sentiment analysis. (GPL-3.0-or-later) - [DKPro](https://dkpro.github.io) - Collection of reusable NLP tools for linguistic pre-processing, machine learning, lexical resources, etc. - [Lingua](https://github.com/pemistahl/lingua) - Natural language detection library, especially suited for short paragraphs of text. -- [LingPipe](http://alias-i.com/lingpipe) - Toolkit for tasks ranging from POS tagging to sentiment analysis. +- [LingPipe](http://alias-i.com/lingpipe/) - Toolkit for tasks ranging from POS tagging to sentiment analysis. ### Networking @@ -688,14 +688,14 @@ _Libraries for building network servers._ - [AkkaGRPC](https://github.com/akka/akka-grpc) - Support for building streaming gRPC servers and clients on top of Akka Streams. - [Comsat](https://github.com/puniverse/comsat) - Integrates standard Java web-related APIs with Quasar fibers and actors. -- [Dubbo](https://github.com/alibaba/dubbo) - High-performance RPC framework. +- [Dubbo](https://github.com/apache/dubbo) - High-performance RPC framework. - [Finagle](https://github.com/twitter/finagle) - Extensible RPC system for constructing high-concurrency servers. It implements uniform client and server APIs for several protocols, and is protocol-agnostic to simplify implementation of new protocols. -- [Grizzly](https://javaee.github.io/grizzly) - NIO framework. Used as a network layer in Glassfish. +- [Grizzly](https://javaee.github.io/grizzly/) - NIO framework. Used as a network layer in Glassfish. - [gRPC](https://github.com/grpc/grpc-java) - RPC framework based on protobuf and HTTP/2. - [KryoNet](https://github.com/EsotericSoftware/kryonet) - Provides a clean and simple API for efficient TCP and UDP client/server network communication using NIO and Kryo. - [MINA](https://mina.apache.org) - Abstract, event-driven async I/O API for network operations over TCP/IP and UDP/IP via Java NIO. - [Netty](https://netty.io) - Framework for building high-performance network applications. -- [Nifty](https://github.com/facebook/nifty) - Implementation of Thrift clients and servers on Netty. +- [Drift](https://github.com/airlift/drift) - Easy-to-use, annotation-based library for creating Thrift clients and serializable types. - [ServiceTalk](https://github.com/apple/servicetalk) - Framework built on Netty with APIs tailored to specific protocols and support for multiple programming paradigms. - [sshj](https://github.com/hierynomus/sshj) - Programatically use SSH, SCP or SFTP. - [TLS Channel](https://github.com/marianobarrios/tls-channel) - Implements a ByteChannel interface over SSLEngine, enabling easy-to-use (socket-like) TLS. @@ -707,34 +707,34 @@ _Libraries for building network servers._ _APIs that handle the persistence of objects._ - [Apache Cayenne](https://cayenne.apache.org) - Provides a clean, static API for data access. Also includes a GUI Modeler for working with database mappings, and DB reverse engineering and generation. -- [Doma 2](https://doma.readthedocs.io) - Database access framework that verifies and generates source code at compile time using annotation processing as well as native SQL templates called two-way SQL. -- [Ebean](https://ebean-orm.github.io) - Provides simple and fast data access. -- [EclipseLink](https://www.eclipse.org/eclipselink) - Supports a number of persistence standards: JPA, JAXB, JCA and SDO. -- [Hibernate](http://hibernate.org/orm) - Robust and widely used, with an active community. (LGPL-2.1-only) -- [MyBatis](http://www.mybatis.org/mybatis-3) - Couples objects with stored procedures or SQL statements. +- [Doma](https://github.com/domaframework/doma) - Database access framework that verifies and generates source code at compile time using annotation processing as well as native SQL templates called two-way SQL. +- [Ebean](https://ebean.io) - Provides simple and fast data access. +- [EclipseLink](https://www.eclipse.org/eclipselink/) - Supports a number of persistence standards: JPA, JAXB, JCA and SDO. +- [Hibernate](http://hibernate.org/orm/) - Robust and widely used, with an active community. (LGPL-2.1-only) +- [MyBatis](https://github.com/mybatis/mybatis-3) - Couples objects with stored procedures or SQL statements. - [SimpleFlatMapper](https://github.com/arnaudroger/SimpleFlatMapper) - Simple database and CSV mapper. ### PaaS _Java platform as a service._ -- [AWS Elastic Beanstalk ![c]](https://aws.amazon.com/elasticbeanstalk) - AWS-based, with support for Tomcat and Jetty. -- [AWS Lambda ![c]](https://aws.amazon.com/lambda) - Serverless computation. +- [AWS Elastic Beanstalk ![c]](https://aws.amazon.com/elasticbeanstalk/) - AWS-based, with support for Tomcat and Jetty. +- [AWS Lambda ![c]](https://aws.amazon.com/lambda/) - Serverless computation. - [Google Cloud ![c]](https://cloud.google.com) - Google's cloud infrastructure. - [Heroku ![c]](https://www.heroku.com) - Abstract computing environments. -- [Microsoft Azure ![c]](https://azure.microsoft.com) - Microsoft's cloud infrastructure. +- [Microsoft Azure ![c]](https://azure.microsoft.com/en-us/) - Microsoft's cloud infrastructure. - [OpenShift ![c]](https://www.openshift.com) - Provides additionally an on-premise solution. ### PDF _Tools to help with PDF file creation._ -- [Apache FOP](https://xmlgraphics.apache.org/fop) - Creates PDFs from XSL-FO. +- [Apache FOP](https://xmlgraphics.apache.org/fop/) - Creates PDFs from XSL-FO. - [Apache PDFBox](https://pdfbox.apache.org) - Toolbox for creating and manipulating PDFs. - [Dynamic Jasper](http://dynamicjasper.com) - Abstraction layer to JasperReports. (LGPL-3.0-only) - [DynamicReports](https://github.com/dynamicreports/dynamicreports) - Simplifies JasperReports. (LGPL-3.0-only) - [flyingsaucer](https://github.com/flyingsaucerproject/flyingsaucer) - XML/XHTML and CSS 2.1 renderer. (LGPL-2.1-or-later) -- [iText ![c]](https://itextpdf.com) - Creates PDF files programmatically. +- [iText ![c]](https://itextpdf.com/en) - Creates PDF files programmatically. - [JasperReports](https://community.jaspersoft.com/project/jasperreports-library) - Complex reporting engine. (LGPL-3.0-only) - [Open HTML to PDF](https://github.com/danfickle/openhtmltopdf) - Properly supports modern PDF standards based on flyingsaucer and Apache PDFBox. - [OpenPDF](https://github.com/LibrePDF/OpenPDF) - Open-source iText fork. (LGPL-3.0-only & MPL-2.0) @@ -743,12 +743,12 @@ _Tools to help with PDF file creation._ _Tools for performance analysis, profiling and benchmarking._ -- [fastThread ![c]](http://fastthread.io) - Analyze and visualize thread dumps with a free cloud-based upload interface. -- [GCeasy ![c]](http://gceasy.io) - Tool to analyze and visualize GC logs. It provides a free cloud-based upload interface. +- [fastThread ![c]](https://fastthread.io) - Analyze and visualize thread dumps with a free cloud-based upload interface. +- [GCeasy ![c]](https://gceasy.io) - Tool to analyze and visualize GC logs. It provides a free cloud-based upload interface. - [honest-profiler](https://github.com/jvm-profiling-tools/honest-profiler) - Low-overhead, bias-free sampling profiler. - [jHiccup](https://github.com/giltene/jHiccup) - Logs and records platform JVM stalls. - [JITWatch](https://github.com/AdoptOpenJDK/jitwatch) - Analyze the JIT compiler optimisations made by the HotSpot JVM. -- [JMH](http://openjdk.java.net/projects/code-tools/jmh) - Harness for building, running, and analysing nano/micro/milli/macro benchmarks written in Java and other languages targeting the JVM. (GPL-2.0 only WITH Classpath-exception-2.0) +- [JMH](http://openjdk.java.net/projects/code-tools/jmh/) - Harness for building, running, and analysing nano/micro/milli/macro benchmarks written in Java and other languages targeting the JVM. (GPL-2.0 only WITH Classpath-exception-2.0) - [LatencyUtils](https://github.com/LatencyUtils/LatencyUtils) - Utilities for latency measurement and reporting. ### Platform @@ -757,67 +757,67 @@ _Frameworks that are suites of multiple libraries encompassing several categorie #### Apache Commons -- [BCEL](http://commons.apache.org/proper/commons-bcel) - Byte Code Engineering Library - analyze, create, and manipulate Java class files. -- [BeanUtils](http://commons.apache.org/proper/commons-beanutils) - Easy-to-use wrappers around the Java reflection and introspection APIs. -- [BeanUtils2](http://commons.apache.org/sandbox/commons-beanutils2) - Redesign of Commons BeanUtils. -- [BSF](http://commons.apache.org/proper/commons-bsf) - Bean Scripting Framework - interface to scripting languages, including JSR-223. -- [Chain](http://commons.apache.org/proper/commons-chain) - Chain of Responsibility pattern implementation. -- [ClassScan](http://commons.apache.org/sandbox/commons-classscan) - Find Class interfaces, methods, fields, and annotations without loading. -- [CLI](http://commons.apache.org/proper/commons-cli) - Command-line arguments parser. -- [CLI2](http://commons.apache.org/sandbox/commons-cli2) - Redesign of Commons CLI. -- [Codec](http://commons.apache.org/proper/commons-codec) - General encoding/decoding algorithms, e.g. phonetic, base64 or URL. -- [Collections](http://commons.apache.org/proper/commons-collections) - Extends or augments the Java Collections Framework. -- [Compress](http://commons.apache.org/proper/commons-compress) - Defines an API for working with tar, zip and bzip2 files. -- [Configuration](http://commons.apache.org/proper/commons-configuration) - Reading of configuration/preferences files in various formats. -- [Convert](http://commons.apache.org/sandbox/commons-convert) - Commons-Convert aims to provide a single library dedicated to the task of converting an object of one type to another. -- [CSV](http://commons.apache.org/proper/commons-csv) - Component for reading and writing comma separated value files. -- [Daemon](http://commons.apache.org/proper/commons-daemon) - Alternative invocation mechanism for unix-daemon-like java code. -- [DBCP](http://commons.apache.org/proper/commons-dbcp) - Database connection pooling services. -- [DbUtils](http://commons.apache.org/proper/commons-dbutils) - JDBC helper library. -- [Digester](http://commons.apache.org/proper/commons-digester) - XML-to-Java-object mapping utility. -- [Email](http://commons.apache.org/proper/commons-email) - Library for sending e-mail from Java. -- [Exec](http://commons.apache.org/proper/commons-exec) - API for dealing with external process execution and environment management in Java. -- [FileUpload](http://commons.apache.org/proper/commons-fileupload) - File upload capability for your servlets and web applications. -- [Finder](http://commons.apache.org/sandbox/commons-finder) - Java library inspired by the UNIX find command. -- [Flatfile](http://commons.apache.org/sandbox/commons-flatfile) - Java library for working with flat data structures. -- [Functor](http://commons.apache.org/proper/commons-functor) - Function that can be manipulated as an object, or an object representing a single, generic function. -- [Graph](http://commons.apache.org/sandbox/commons-graph) - General purpose graph APIs and algorithms. -- [I18n](http://commons.apache.org/sandbox/commons-i18n) - Adds the feature of localized message bundles that consist of one or many localized texts that belong together. -- [Id](http://commons.apache.org/sandbox/commons-id) - Id is a component used to generate identifiers. -- [Imaging](http://commons.apache.org/proper/commons-imaging) - Image library. -- [IO](http://commons.apache.org/proper/commons-io) - Collection of I/O utilities. -- [Javaflow](http://commons.apache.org/sandbox/commons-javaflow) - Continuation implementation to capture the state of the application. -- [JCI](http://commons.apache.org/proper/commons-jci) - Java Compiler Interface. -- [JCS](http://commons.apache.org/proper/commons-jcs) - Java Caching System. -- [Jelly](http://commons.apache.org/proper/commons-jelly) - XML based scripting and processing engine. -- [Jexl](http://commons.apache.org/proper/commons-jexl) - Expression language which extends the Expression Language of the JSTL. -- [JNet](http://commons.apache.org/sandbox/commons-jnet) - JNet allows to use dynamically register url stream handlers through the java.net API. -- [JXPath](http://commons.apache.org/proper/commons-jxpath) - Utilities for manipulating Java Beans using the XPath syntax. -- [Lang](http://commons.apache.org/proper/commons-lang) - Provides extra functionality for classes in java.lang. -- [Logging](https://en.wikipedia.org/wiki/Apache_Commons_Logging) - Wrapper around a variety of logging API implementations. -- [Math](http://commons.apache.org/proper/commons-math) - Lightweight, self-contained mathematics and statistics components. -- [Monitoring](http://commons.apache.org/sandbox/commons-monitoring) - Monitoring aims to provide a simple but extensible monitoring solution for Java applications. -- [Nabla](http://commons.apache.org/sandbox/commons-nabla) - Nabla provides automatic differentiation classes that can generate derivative of any function implemented in the Java language. -- [Net](http://commons.apache.org/proper/commons-net) - Collection of network utilities and protocol implementations. -- [OGNL](http://commons.apache.org/proper/commons-ognl) - Object-graph navigation language. -- [OpenPGP](http://commons.apache.org/sandbox/commons-openpgp) - Interface to signing and verifying data using OpenPGP. -- [Performance](http://commons.apache.org/sandbox/commons-performance) - Small framework for microbenchmark clients, with implementations for Commons DBCP and Pool. -- [Pipeline](http://commons.apache.org/sandbox/commons-pipeline) - Provides a set of pipeline utilities designed around work queues that run in parallel to sequentially process data objects. -- [Pool](http://commons.apache.org/proper/commons-pool) - Generic object pooling component. -- [Proxy](http://commons.apache.org/proper/commons-proxy) - Library for creating dynamic proxies. -- [RDF](https://commons.apache.org/proper/commons-rdf) - Common implementation of RDF 1.1 that could be implemented by systems on the JVM. -- [RNG](https://commons.apache.org/proper/commons-rng) - Commons Rng provides implementations of pseudo-random numbers generators. -- [SCXML](http://commons.apache.org/proper/commons-scxml) - Implementation of the State Chart XML specification aimed at creating and maintaining a Java SCXML engine. -- [Validator](http://commons.apache.org/proper/commons-validator) - Framework to define validators and validation rules in an xml file. -- [VFS](http://commons.apache.org/proper/commons-vfs) - Virtual File System component for treating files, FTP, SMB, ZIP and such like as a single logical file system. -- [Weaver](http://commons.apache.org/proper/commons-weaver) - Provides an easy way to enhance (weave) compiled bytecode. +- [BCEL](http://commons.apache.org/proper/commons-bcel/) - Byte Code Engineering Library - analyze, create, and manipulate Java class files. +- [BeanUtils](http://commons.apache.org/proper/commons-beanutils/) - Easy-to-use wrappers around the Java reflection and introspection APIs. +- [BeanUtils2](http://commons.apache.org/sandbox/commons-beanutils2/) - Redesign of Commons BeanUtils. +- [BSF](http://commons.apache.org/proper/commons-bsf/) - Bean Scripting Framework - interface to scripting languages, including JSR-223. +- [Chain](http://commons.apache.org/proper/commons-chain/) - Chain of Responsibility pattern implementation. +- [ClassScan](http://commons.apache.org/sandbox/commons-classscan/) - Find Class interfaces, methods, fields, and annotations without loading. +- [CLI](http://commons.apache.org/proper/commons-cli/) - Command-line arguments parser. +- [CLI2](http://commons.apache.org/sandbox/commons-cli2/) - Redesign of Commons CLI. +- [Codec](http://commons.apache.org/proper/commons-codec/) - General encoding/decoding algorithms, e.g. phonetic, base64 or URL. +- [Collections](http://commons.apache.org/proper/commons-collections/) - Extends or augments the Java Collections Framework. +- [Compress](http://commons.apache.org/proper/commons-compress/) - Defines an API for working with tar, zip and bzip2 files. +- [Configuration](http://commons.apache.org/proper/commons-configuration/) - Reading of configuration/preferences files in various formats. +- [Convert](http://commons.apache.org/sandbox/commons-convert/) - Commons-Convert aims to provide a single library dedicated to the task of converting an object of one type to another. +- [CSV](http://commons.apache.org/proper/commons-csv/) - Component for reading and writing comma separated value files. +- [Daemon](http://commons.apache.org/proper/commons-daemon/) - Alternative invocation mechanism for unix-daemon-like java code. +- [DBCP](http://commons.apache.org/proper/commons-dbcp/) - Database connection pooling services. +- [DbUtils](http://commons.apache.org/proper/commons-dbutils/) - JDBC helper library. +- [Digester](http://commons.apache.org/proper/commons-digester/) - XML-to-Java-object mapping utility. +- [Email](http://commons.apache.org/proper/commons-email/) - Library for sending e-mail from Java. +- [Exec](http://commons.apache.org/proper/commons-exec/) - API for dealing with external process execution and environment management in Java. +- [FileUpload](http://commons.apache.org/proper/commons-fileupload/) - File upload capability for your servlets and web applications. +- [Finder](http://commons.apache.org/sandbox/commons-finder/) - Java library inspired by the UNIX find command. +- [Flatfile](http://commons.apache.org/sandbox/commons-flatfile/) - Java library for working with flat data structures. +- [Functor](http://commons.apache.org/proper/commons-functor/) - Function that can be manipulated as an object, or an object representing a single, generic function. +- [Graph](http://commons.apache.org/sandbox/commons-graph/) - General purpose graph APIs and algorithms. +- [I18n](http://commons.apache.org/sandbox/commons-i18n/) - Adds the feature of localized message bundles that consist of one or many localized texts that belong together. +- [Id](http://commons.apache.org/sandbox/commons-id/) - Id is a component used to generate identifiers. +- [Imaging](http://commons.apache.org/proper/commons-imaging/) - Image library. +- [IO](http://commons.apache.org/proper/commons-io/) - Collection of I/O utilities. +- [Javaflow](http://commons.apache.org/sandbox/commons-javaflow/) - Continuation implementation to capture the state of the application. +- [JCI](http://commons.apache.org/proper/commons-jci/) - Java Compiler Interface. +- [JCS](http://commons.apache.org/proper/commons-jcs/) - Java Caching System. +- [Jelly](http://commons.apache.org/proper/commons-jelly/) - XML based scripting and processing engine. +- [Jexl](http://commons.apache.org/proper/commons-jexl/) - Expression language which extends the Expression Language of the JSTL. +- [JNet](http://commons.apache.org/sandbox/commons-jnet/) - JNet allows to use dynamically register url stream handlers through the java.net API. +- [JXPath](http://commons.apache.org/proper/commons-jxpath/) - Utilities for manipulating Java Beans using the XPath syntax. +- [Lang](http://commons.apache.org/proper/commons-lang/) - Provides extra functionality for classes in java.lang. +- [Logging](https://commons.apache.org/proper/commons-logging/) - Wrapper around a variety of logging API implementations. +- [Math](http://commons.apache.org/proper/commons-math/) - Lightweight, self-contained mathematics and statistics components. +- [Monitoring](http://commons.apache.org/sandbox/commons-monitoring/) - Monitoring aims to provide a simple but extensible monitoring solution for Java applications. +- [Nabla](http://commons.apache.org/sandbox/commons-nabla/) - Nabla provides automatic differentiation classes that can generate derivative of any function implemented in the Java language. +- [Net](http://commons.apache.org/proper/commons-net/) - Collection of network utilities and protocol implementations. +- [OGNL](http://commons.apache.org/proper/commons-ognl/) - Object-graph navigation language. +- [OpenPGP](http://commons.apache.org/sandbox/commons-openpgp/) - Interface to signing and verifying data using OpenPGP. +- [Performance](http://commons.apache.org/sandbox/commons-performance/) - Small framework for microbenchmark clients, with implementations for Commons DBCP and Pool. +- [Pipeline](http://commons.apache.org/sandbox/commons-pipeline/) - Provides a set of pipeline utilities designed around work queues that run in parallel to sequentially process data objects. +- [Pool](http://commons.apache.org/proper/commons-pool/) - Generic object pooling component. +- [Proxy](http://commons.apache.org/proper/commons-proxy/) - Library for creating dynamic proxies. +- [RDF](https://commons.apache.org/proper/commons-rdf/) - Common implementation of RDF 1.1 that could be implemented by systems on the JVM. +- [RNG](https://commons.apache.org/proper/commons-rng/) - Commons Rng provides implementations of pseudo-random numbers generators. +- [SCXML](http://commons.apache.org/proper/commons-scxml/) - Implementation of the State Chart XML specification aimed at creating and maintaining a Java SCXML engine. +- [Validator](http://commons.apache.org/proper/commons-validator/) - Framework to define validators and validation rules in an xml file. +- [VFS](http://commons.apache.org/proper/commons-vfs/) - Virtual File System component for treating files, FTP, SMB, ZIP and such like as a single logical file system. +- [Weaver](http://commons.apache.org/proper/commons-weaver/) - Provides an easy way to enhance (weave) compiled bytecode. #### Other -- [CUBA Platform](https://cuba-platform.com) - High-level framework for developing enterprise applications with a rich web interface, based on Spring, EclipseLink and Vaadin. -- [Light-Java](https://github.com/networknt/light-java) - Fast, lightweight and productive microservices framework with built-in [security](https://github.com/networknt/light-oauth2). -- [Orienteer](https://github.com/OrienteerBAP/Orienteer) - Open-source business application platform for rapid configuration/development of CRM, ERP, LMS and other applications. -- [Spring](https://spring.io/projects) - Provides many packages for dependency injection, aspect-oriented programming, security, etc. +- [CUBA Platform](https://www.cuba-platform.com/) - High-level framework for developing enterprise applications with a rich web interface, based on Spring, EclipseLink and Vaadin. +- [Light-4J](https://github.com/networknt/light-4j/) - Fast, lightweight and productive microservices framework with built-in [security](https://github.com/networknt/light-oauth2/). +- [Orienteer](https://github.com/OrienteerBAP/Orienteer/) - Open-source business application platform for rapid configuration/development of CRM, ERP, LMS and other applications. +- [Spring](https://spring.io/projects/) - Provides many packages for dependency injection, aspect-oriented programming, security, etc. ### Processes @@ -833,7 +833,7 @@ _Libraries for developing reactive applications._ - [Akka](https://akka.io) - Toolkit and runtime for building concurrent, distributed, fault-tolerant and event-driven applications. - [Reactive Streams](https://github.com/reactive-streams/reactive-streams-jvm) - Provides a standard for asynchronous stream processing with non-blocking backpressure. -- [Reactor](https://projectreactor.io) - Library for building reactive fast-data applications. +- [Reactor](https://github.com/reactor/reactor-core) - Library for building reactive fast-data applications. - [RxJava](https://github.com/ReactiveX/RxJava) - Allows for composing asynchronous and event-based programs using observable sequences. - [vert.x](https://vertx.io) - Polyglot event-driven application framework. @@ -841,14 +841,14 @@ _Libraries for developing reactive applications._ _Frameworks specifically for creating RESTful services._ -- [Dropwizard](https://dropwizard.github.io/dropwizard) - Opinionated framework for setting up modern web applications with Jetty, Jackson, Jersey and Metrics. -- [Elide](http://elide.io) - Opinionated framework for JSON- or GraphQL-APIs based on a JPA data model. +- [Dropwizard](https://github.com/dropwizard/dropwizard) - Opinionated framework for setting up modern web applications with Jetty, Jackson, Jersey and Metrics. +- [Elide](https://elide.io) - Opinionated framework for JSON- or GraphQL-APIs based on a JPA data model. - [javalin](https://javalin.io) - Javalin is just a few thousand lines of code on top of Jetty, which means its performance is almost equivalent to pure Jetty. - [Jersey](https://jersey.github.io) - JAX-RS reference implementation. -- [Microserver](https://github.com/aol/micro-server) - A convenient, extensible microservices plugin system for Spring & Spring Boot. With more than 30 plugins and growing, it supports both micro-monolith and pure microservices styles. +- [Microserver](https://github.com/aol/micro-server) - Convenient, extensible microservices plugin system for Spring & Spring Boot. With more than 30 plugins and growing, it supports both micro-monolith and pure microservices styles. - [Rapidoid](https://www.rapidoid.org) - Simple, secure and extremely fast framework consisting of an embedded HTTP server, GUI components and dependency injection. - [rest.li](https://github.com/linkedin/rest.li) - Framework for building robust, scalable RESTful architectures using typesafe bindings and asynchronous, non-blocking IO with an end-to-end developer workflow that promotes clean practices, uniform interface design and consistent data modeling. -- [RESTEasy](https://resteasy.jboss.org) - Fully certified and portable implementation of the JAX-RS specification. +- [RESTEasy](https://resteasy.github.io) - Fully certified and portable implementation of the JAX-RS specification. - [RestExpress](https://github.com/RestExpress/RestExpress) - Thin wrapper on the JBoss Netty HTTP stack that provides scaling and performance. - [Restlet Framework](https://github.com/restlet/restlet-framework-java) - Pioneering framework with powerful routing and filtering capabilities, and a unified client and server API. - [Spark](http://sparkjava.com) - Sinatra inspired framework. @@ -860,16 +860,16 @@ _Frameworks specifically for creating RESTful services._ _Libraries for scientific computing, analysis and visualization._ -- [DataMelt](http://jwork.org/dmelt) - Environment for scientific computation, data analysis and data visualization. (GPL-3.0-or-later) +- [DataMelt](https://jwork.org/dmelt/) - Environment for scientific computation, data analysis and data visualization. (GPL-3.0-or-later) - [Erdos](https://github.com/Erdos-Graph-Framework/Erdos) - Modular, light and easy graph framework for theoretic algorithms. - [GraphStream](http://graphstream-project.org) - Library for modeling and analyzing dynamic graphs. -- [JFreeChart](http://www.jfree.org/jfreechart) - 2D chart library for Swing, JavaFX and server-side applications. (LGPL-2.1-only) +- [JFreeChart](http://www.jfree.org/jfreechart/) - 2D chart library for Swing, JavaFX and server-side applications. (LGPL-2.1-only) - [JGraphT](https://github.com/jgrapht/jgrapht) - Graph library that provides mathematical graph-theory objects and algorithms. - [JGraphX](https://github.com/jgraph/jgraphx) - Library for visualizing (mainly Swing) and interacting with node-edge graphs. - [Mines Java Toolkit](https://github.com/MinesJTK/jtk) - Library for geophysical scientific computation, visualization and digital signal analysis. -- [Morpheus](http://www.zavtech.com/morpheus/docs) - Provides a versatile two-dimensional memory efficient tabular data structure called a DataFrame to enable efficient in-memory analytics for scientific computing on the JVM. +- [Morpheus](https://github.com/zavtech/morpheus-core) - Provides a versatile two-dimensional memory efficient tabular data structure called a DataFrame to enable efficient in-memory analytics for scientific computing on the JVM. - [Orson-Charts](https://github.com/jfree/orson-charts) - Generates a wide variety of 3D charts that can be displayed with Swing and JavaFX or exported to PDF, SVG, PNG and JPEG. (GPL-3.0-only) -- [Tablesaw](https://github.com/lwhite1/tablesaw) - Includes a data-frame, an embedded column store, and hundreds of methods to transform, summarize, or filter data. +- [Tablesaw](https://github.com/jtablesaw/tablesaw) - Includes a data-frame, an embedded column store, and hundreds of methods to transform, summarize, or filter data. - [XChart](https://github.com/knowm/XChart) - Light-weight library for plotting data. Many customizable chart types are available. ### Search @@ -877,7 +877,7 @@ _Libraries for scientific computing, analysis and visualization._ _Engines that index documents for search and analysis._ - [Apache Lucene](https://lucene.apache.org) - High-performance, full-featured, cross-platform, text search engine library. -- [Apache Solr](https://lucene.apache.org/solr) - Enterprise search engine optimized for high-volume traffic. +- [Apache Solr](https://lucene.apache.org/solr/) - Enterprise search engine optimized for high-volume traffic. - [Elasticsearch](https://www.elastic.co) - Distributed, multitenant-capable, full-text search engine with a RESTful web interface and schema-free JSON documents. - [Indexer4j](https://github.com/haeungun/indexer4j) - Simple and light full text indexing and searching library. @@ -918,20 +918,20 @@ _Servers specifically used to deploy applications._ - [Apache Tomcat](https://tomcat.apache.org) - Robust, all-round server for Servlet and JSP. - [Apache TomEE](https://tomee.apache.org) - Tomcat plus Java EE. -- [Jetty](https://www.eclipse.org/jetty) - Provides a Web server and javax.servlet container, plus support for HTTP/2, WebSocket, OSGi, JMX, JNDI, JAAS and many other integrations. +- [Jetty](https://www.eclipse.org/jetty/) - Provides a Web server and javax.servlet container, plus support for HTTP/2, WebSocket, OSGi, JMX, JNDI, JAAS and many other integrations. - [nanohttpd](https://github.com/NanoHttpd/nanohttpd) - Tiny, easily embeddable HTTP server. -- [WildFly](http://www.wildfly.org) - Formerly known as JBoss and developed by Red Hat with extensive Java EE support. (LGPL-2.1-only) +- [WildFly](https://www.wildfly.org) - Formerly known as JBoss and developed by Red Hat with extensive Java EE support. (LGPL-2.1-only) ### Template Engine _Tools that substitute expressions in a template._ -- [Handlebars.java](https://jknack.github.io/handlebars.java) - Logicless and semantic Mustache templates. +- [Handlebars.java](https://jknack.github.io/handlebars.java/) - Logicless and semantic Mustache templates. - [Jade4J](https://github.com/neuland/jade4j) - Implementation of Pug (formerly known as Jade). - [Jtwig](http://jtwig.org) - Modular, configurable and fully tested template engine. - [Pebble](https://pebbletemplates.io) - Inspired by Twig and separates itself with its inheritance feature and its easy-to-read syntax. It ships with built-in autoescaping for security and it includes integrated support for internationalization. - [Rocker](https://github.com/fizzed/rocker) - Optimized, memory efficient and speedy template engine producing statically typed, plain objects. -- [Thymeleaf](http://www.thymeleaf.org) - Aims to be a substitute for JSP and works for XML files. +- [Thymeleaf](https://www.thymeleaf.org) - Aims to be a substitute for JSP and works for XML files. ### Testing @@ -941,11 +941,11 @@ _Tools that test from model to the view._ _Tools that simplify testing asynchronous services._ -- [Awaitility](https://github.com/jayway/awaitility) - DSL for synchronizing asynchronous operations. +- [Awaitility](https://github.com/awaitility/awaitility) - DSL for synchronizing asynchronous operations. - [ConcurrentUnit](https://github.com/jhalterman/concurrentunit) - Toolkit for testing multi-threaded and asynchronous applications. -- [GreenMail](http://www.icegreen.com/greenmail) - In-memory email server for integration testing. Supports SMTP, POP3 and IMAP including SSL. (GPL-2.0-only) +- [GreenMail](http://www.icegreen.com/greenmail/) - In-memory email server for integration testing. Supports SMTP, POP3 and IMAP including SSL. (GPL-2.0-only) - [Hoverfly Java](https://github.com/SpectoLabs/hoverfly-java) - Native bindings for Hoverfly, a proxy which allows you to simulate HTTP services. -- [REST Assured](https://github.com/jayway/rest-assured) - DSL for easy testing of REST/HTTP services. +- [REST Assured](https://github.com/rest-assured/rest-assured) - DSL for easy testing of REST/HTTP services. - [Karate](https://github.com/intuit/karate) - DSL that combine API test-automation, mocks and performance-testing making testing REST/HTTP services easy. #### BDD @@ -953,12 +953,12 @@ _Tools that simplify testing asynchronous services._ _Testing for the software development process that emerged from TDD and was heavily influenced by DDD and OOAD._ - [Cucumber](https://github.com/cucumber/cucumber-jvm) - Provides a way to describe features in a plain language which customers can understand. -- [Cukes-REST](https://github.com/ctco/cukes-rest) - Collection of Gherkin steps for REST-service testing using Cucumber. +- [Cukes-REST](https://github.com/ctco/cukes) - Collection of Gherkin steps for REST-service testing using Cucumber. - [J8Spec](https://github.com/j8spec/j8spec) - Follows a Jasmine-like syntax. -- [JBehave](http://jbehave.org) - Extensively configurable framework that describes stories. +- [JBehave](https://jbehave.org) - Extensively configurable framework that describes stories. - [JGiven](http://jgiven.org) - Provides a fluent API which allows for simpler composition. - [Lamdba Behave](https://github.com/RichardWarburton/lambda-behave) - Aims to provide a fluent API to write tests in long and descriptive sentences that read like plain English. -- [Serenity BDD](https://www.thucydides.info) - Automated Acceptance testing and reporting library that works with Cucumber, JBehave and JUnit to make it easier to write high quality executable specifications. +- [Serenity BDD](https://github.com/serenity-bdd/serenity-core) - Automated Acceptance testing and reporting library that works with Cucumber, JBehave and JUnit to make it easier to write high quality executable specifications. #### Fixtures @@ -979,7 +979,7 @@ _Provide environments to run tests for a specific use case._ - [Arquillian](http://arquillian.org) - Integration and functional testing platform for Java EE containers. - [Citrus](https://citrusframework.org) - Integration testing framework that focuses on both client- and server-side messaging. - [Gatling](https://gatling.io) - Load testing tool designed for ease of use, maintainability and high performance. -- [JUnit](http://junit.org) - Common testing framework. +- [JUnit](https://junit.org/junit5/) - Common testing framework. - [jqwik](https://jqwik.net) - Engine for property-based testing built on JUnit 5. - [Pact JVM](https://github.com/DiUS/pact-jvm) - Consumer-driven contract testing. - [PIT](http://pitest.org) - Fast mutation-testing framework for evaluating fault-detection abilities of existing JUnit or TestNG test suites. @@ -988,8 +988,8 @@ _Provide environments to run tests for a specific use case._ _Libraries that provide custom matchers._ -- [AssertJ](https://joel-costigliola.github.io/assertj) - Fluent assertions that improve readability. -- [Hamcrest](http://hamcrest.org/JavaHamcrest) - Matchers that can be combined to create flexible expressions of intent. +- [AssertJ](https://joel-costigliola.github.io/assertj/) - Fluent assertions that improve readability. +- [Hamcrest](http://hamcrest.org/JavaHamcrest/) - Matchers that can be combined to create flexible expressions of intent. - [JSONAssert](http://jsonassert.skyscreamer.org) - Simplifies testing JSON strings. - [Truth](https://truth.dev) - Google's fluent assertion and proposition framework. - [XMLUnit](https://github.com/xmlunit/xmlunit) - Simplifies testing for XML output. @@ -1002,7 +1002,7 @@ _Other stuff related to testing._ - [Mutability Detector](https://github.com/MutabilityDetector/MutabilityDetector) - Reports whether instances of a given class are immutable. - [raml-tester](https://github.com/nidi3/raml-tester) - Tests if a request/response matches a given RAML definition. - [TestContainers](https://github.com/testcontainers/testcontainers-java) - Provides throwaway instances of common databases, Selenium web browsers, or anything else that can run in a Docker container. -- [pojo-tester](http://www.pojo.pl) - Automatically performs tests on basic POJO methods. (LGPL-3.0-only) +- [pojo-tester](https://www.pojo.pl) - Automatically performs tests on basic POJO methods. (LGPL-3.0-only) #### Mocking @@ -1012,7 +1012,7 @@ _Tools which mock collaborators to help testing single, isolated units._ - [Mockito](https://github.com/mockito/mockito) - Mocking framework that lets you write tests with a clean and simple API. - [MockServer](https://www.mock-server.com) - Allows mocking of systems integrated with HTTPS. - [Moco](https://github.com/dreamhead/moco) - Concise web services for stubs and mocks. -- [PowerMock](https://github.com/jayway/powermock) - Mocks static methods, constructors, final classes and methods, private methods, and removal of static initializers. +- [PowerMock](https://github.com/powermock/powermock) - Mocks static methods, constructors, final classes and methods, private methods, and removal of static initializers. - [WireMock](http://wiremock.org) - Stubs and mocks web services. ### Utility @@ -1020,16 +1020,16 @@ _Tools which mock collaborators to help testing single, isolated units._ _Libraries which provide general utility functions._ - [bucket4j](https://github.com/vladimir-bukhtoyarov/bucket4j) - Rate limiting library based on token-bucket algorithm. -- [cactoos](http://www.cactoos.org) - Collection of object-oriented primitives. +- [cactoos](https://github.com/yegor256/cactoos) - Collection of object-oriented primitives. - [CRaSH](http://www.crashub.org) - Provides a shell into a JVM that's running CRaSH. Used by Spring Boot and others. (LGPL-2.1-or-later) - [Dex](https://github.com/PatMartin/Dex) - Java/JavaFX tool capable of powerful ETL and data visualization. -- [Embulk](http://www.embulk.org) - Bulk data loader that helps data transfer between various databases, storages, file formats, and cloud services. +- [Embulk](https://github.com/embulk/embulk) - Bulk data loader that helps data transfer between various databases, storages, file formats, and cloud services. - [fswatch](https://github.com/vorburger/ch.vorburger.fswatch) - Micro library to watch for directory file system changes, simplifying java.nio.file.WatchService. - [Gephi](https://github.com/gephi/gephi) - Cross-platform for visualizing and manipulating large graph networks. (GPL-3.0-only) - [Guava](https://github.com/google/guava) - Collections, caching, primitives support, concurrency libraries, common annotations, string processing, I/O, and more. - [JADE](http://jade.tilab.com) - Framework and environment for building and debugging multi-agent systems. (LGPL-2.0-only) - [JavaVerbalExpressions](https://github.com/VerbalExpressions/JavaVerbalExpressions) - Library that helps with constructing difficult regular expressions. -- [JGit](https://eclipse.org/jgit) - Lightweight, pure Java library implementing the Git version control system. +- [JGit](https://www.eclipse.org/jgit/) - Lightweight, pure Java library implementing the Git version control system. - [minio-java](https://github.com/minio/minio-java) - Provides simple APIs to access any Amazon S3-compatible object storage server. - [Protégé](https://protege.stanford.edu) - Provides an ontology editor and a framework to build knowledge-based systems. - [Underscore-java](https://github.com/javadev/underscore-java) - Port of Underscore.js functions. @@ -1039,7 +1039,7 @@ _Libraries which provide general utility functions._ _Utilities that help create the development shell environment and switch between different Java versions._ - [jabba](https://github.com/shyiko/jabba) - Java Version Manager inspired by nvm. Supports macOS, Linux and Windows. -- [jenv](https://github.com/gcuisinier/jenv) - Java Version Manager inspired by rbenv. Can configure globally or per project. Tested on Debian and macOS. +- [jenv](https://github.com/jenv/jenv) - Java Version Manager inspired by rbenv. Can configure globally or per project. Tested on Debian and macOS. - [SDKMan](https://github.com/sdkman/sdkman-cli) - Java Version Manager inspired by RVM and rbenv. Supports UNIX-based platforms and Windows. ### Web Crawling @@ -1058,18 +1058,18 @@ _Frameworks that handle the communication between the layers of a web applicatio - [Apache Tapestry](https://tapestry.apache.org) - Component-oriented framework for creating dynamic, robust, highly scalable web applications. - [Apache Wicket](https://wicket.apache.org) - Component-based web application framework similar to Tapestry, with a stateful GUI. -- [Blade](https://github.com/biezhi/blade) - Lightweight, modular framework that aims to be elegant and simple. +- [Blade](https://github.com/lets-blade/blade) - Lightweight, modular framework that aims to be elegant and simple. - [Bootique](https://bootique.io) - Minimally opinionated framework for runnable apps. - [Firefly](http://www.fireflysource.com) - Asynchronous framework for rapid development of high-performance web application. - [Grails](https://grails.org) - Groovy framework that provides a highly productive environment by favoring convention over configuration, no XML and support for mixins. -- [Jooby](http://jooby.org) - Scalable, fast and modular micro-framework that offers multiple programming models. +- [Jooby](http://www.jooby.org) - Scalable, fast and modular micro-framework that offers multiple programming models. - [Ninja](http://www.ninjaframework.org) - Full-stack web framework. - [Pippo](http://www.pippo.ro) - Small, highly modularized, Sinatra-like framework. - [Play](https://www.playframework.com) - Built on Akka, it provides predictable and minimal resource consumption (CPU, memory, threads) for highly-scalable applications in Java and Scala. -- [PrimeFaces](https://primefaces.org) - JSF framework with both free and commercial/support versions and frontend components. +- [PrimeFaces](https://www.primefaces.org) - JSF framework with both free and commercial/support versions and frontend components. - [Ratpack](https://ratpack.io) - Set of libraries that facilitate fast, efficient, evolvable and well-tested HTTP applications. - [Takes](https://github.com/yegor256/takes) - Opinionated web framework which is built around the concepts of True Object-Oriented Programming and immutability. -- [Vaadin Flow](https://vaadin.com/flow) - Event-driven framework that uses standard web components. Server-side architecture with Ajax on the client side. +- [Vaadin](https://vaadin.com) - Event-driven framework that uses standard web components. Server-side architecture with Ajax on the client side. ## Resources @@ -1093,7 +1093,7 @@ _Awesome lists related to the Java & JVM ecosystem._ _Active discussions._ -- [r/java](https://www.reddit.com/r/java) - Subreddit for the Java community. +- [r/java](https://www.reddit.com/r/java/) - Subreddit for the Java community. - [Stack Overflow](https://stackoverflow.com/questions/tagged/java) - Question/answer platform. - [VirtualJUG](https://virtualjug.com) - Virtual Java User Group. @@ -1118,7 +1118,6 @@ _Books that made a big impact and are still worth reading._ _Something to look at or listen to while programming._ - [Java Off Heap](http://www.javaoffheap.com) -- [Marco Behler's Screencasts](https://www.marcobehler.com/series) - Screencasts about modern Java development. - [The Java Council](https://virtualjug.com/#podcast) - [The Java Posse](http://www.javaposse.com) - Discontinued as of 02/2015.