Java Awesome

构建

项目管理及自动构建工具。

  • Apache Maven:Maven使用声明进行构建并进行依赖管理,偏向于使用约定而不是配置进行构建。在大型项目开发中,使用Maven来管理是必不可少的。如果你使用Maven,你可以从Maven中央仓库下载所需要的构件,但这通常不是一个好的做法,你应该在本地架设一个Maven仓库服务器,在代理远程仓库的同时维护本地仓库,以节省带宽和时间,Nexus 就可以满足这样的需要。
  • Gradle:Gradle采用增量构建,Gradle通过Groovy编程而不是传统的XML声明进行配置,其可以很好地配合Maven进行依赖管理,并且把Ant脚本当作头等公民。

代码分析

软件质量评估工具。

  • Checkstyle:一个可帮助程序员编写符合规范代码的开发工具。
  • SonarQube:一个开源的代码质量管理系统,它可以通过使用插件机制与 EclipseJIRA 等其他外部工具集成,从而实现了对代码的质量的全面自动化分析和管理。
  • FindBugs:通过静态分析来识别Java程序中潜在Bug。
  • PMD:源代码分析器。

持续集成

支持持续集成、测试和应用发布的工具。

  • Jenkins:提供了基于服务器部署持续集成服务,其前身是 Hudson 项目。
  • TeamCity:JetBrains持续集成方案。
  • Travis:提供托管服务,常用于开源项目。
  • Bamboo:Atlassian的持续集成解决方案,包含很多其它产品。
  • Go:ThoughtWorks开源持续集成解决方案。
  • CircleCI:提供托管服务,可免费试用。
  • Codeship:提供托管服务,提供有限免费计划。

IDE

集成开发环境。

  • IntelliJ IDEA:IntelliJ IDEA被认为是当前Java开发效率最快的IDE工具,它集成了开发过程中实用的众多功能,几乎可以不用鼠标便能完成你要做的任何事情,最大程度的加快开发的速度。
  • Eclipse:著名的跨平台开源集成开发环境,以其丰富插件著称。
  • NetBeans:集成了很多Java SE和Java EE特性,包括数据库访问、服务器、HTML5以及AngularJS。

机器学习

提供具体统计算法的工具,其算法可从数据中学习。

  • Apache Hadoop:商用硬件集群上大规模数据存储和处理的开源软件框架。Hadoop是根据谷歌公司发表的MapReduce和Google文件系统的论文自行实现而成。Hadoop实现了名为MapReduce的编程范式:应用程序被分区成许多小部分,而每个部分都能在集群中的任意节点上运行或重新运行。此外,Hadoop还提供了分布式文件系统,用以存储所有计算节点的数据,这为整个集群带来了非常高的带宽。MapReduce(并行计算框架)和HDFS(分布式文件系统)的设计,使得整个框架能够自动处理节点故障。
  • Apache Spark:大数据内存计算框架。相对于Hadoop的MapReduce会在运行完工作后将中介数据存放到磁盘中,Spark使用了内存内运算技术,能在数据尚未写入硬盘时即在内存内分析运算。Spark在内存内运行程序的运算速度能做到比Hadoop MapReduce的运算速度快上100倍,即便是运行程序于硬盘时,Spark也能快上10倍速度。Spark允许用户将数据加载至簇内存,并多次对其进行查询,非常适合用于机器学习算法。
  • Apache Mahout:机器学习算法软件包。
  • H2O:用作大数据统计的分析引擎。
  • Weka:用作数据挖掘的算法集合,包括从预处理到可视化的各个层次。

分布式应用

用来开发分布式、具有容错性应用程序的函数库和框架。

  • Apache ZooKeeper:使用分布式配置、同步和命名注册为大型分布式系统提供协调服务。
  • Apache Storm:分布式实时计算系统。提供与MapReduce作业类似的功能。
  • Akka:构建高并发和分布式 JVM 应用程序的工具包。
  • Atomix:基于事件驱动的容错分布式协调框架。
  • Hazelcast:分布式、高可扩展性内存数据网格。
  • Hystrix:为分布式系统提供延迟和容错处理。
  • JGroups:一组提供可靠消息传输的工具包,可用来创建集群,集群中的节点可互相发送消息。
  • Quasar:为JVM提供轻量级线程和Actor。

数据库

简化数据库交互的工具。

  • Apache HBase:分布式NoSQL列数据库,类似谷歌公司BigTable。它是Apache软件基金会的Hadoop项目的一部分,运行于HDFS文件系统之上,为 Hadoop 提供类似于BigTable规模的服务。
  • Apache Hive:构建于hadoop之上的数据仓库,通过一种类SQL语言HiveQL为用户提供数据的归纳、查询和分析等功能。
  • Presto:针对大数据的分布式SQL查询引擎。
  • H2:小型SQL数据库,以内存操作著称。
  • Flyway:使用Java API轻松完成数据库迁移。
  • JDBI:便捷的JDBC抽象。
  • jOOQ:基于SQL schema生成类型安全代码。
  • Querydsl:针对Java的类型安全统一查询。

服务器

用来部署应用程序的服务器。

  • Apache Tomcat:针对Servlet和JSP的应用服务器,健壮性好且适用性强。
  • Apache TomEE:Tomcat加Java EE。
  • Jetty:轻量级、小巧的应用服务器,通常用作嵌入式Web容器。
  • GlassFish:Java EE开源参考实现,由Oracle资助开发。
  • WildFly:之前被称作JBoss,由Redhat开发,支持很多Java EE功能。

消息

在客户端之间进行消息传递,确保协议独立性的工具。

  • Apache Kafka:高吞吐量分布式消息系统。
  • Apache ActiveMQ:实现JMS的开源消息代理,可将同步通讯转为异步通讯。
  • Apache RocketMQ:阿里开源的一款高性能、高吞吐量的消息中间件。
  • JBoss HornetQ:清晰、准确、模块化且方便嵌入的消息工具。
  • JeroMQ:ZeroMQ的纯Java实现。

搜索

文档索引引擎,用于搜索和分析。

  • Elasticsearch:一种分布式、支持REST风格的搜索和分析引擎。
  • Apache Lucene:高性能、功能全面的跨平台文本搜索引擎库。
  • Apache Solr:采用Lucene搜索库为核心,提供全文索引和搜索开源企业平台。

网络

网络编程函数库。

  • Apache MINA:一个开发高性能和高可伸缩性网络应用程序的网络应用框架,提供了一个抽象的事件驱动的异步 API,可以使用 TCP/IP、UDP/IP、串口和虚拟机内部的管道等传输方式。
  • Netty:构建高性能网络应用程序开发框架。
  • Hessian:一个轻量级的remoting onhttp工具,使用简单的方法提供了RMI的功能,相比WebService,Hessian更简单、快捷。
  • Grizzly:用于网络层的Grizzly NIO框架。
  • gRPC:基于protobuf和HTTP/2的RPC框架。
  • OkHttp:一个Android和Java应用的HTTP+SPDY客户端。

网络爬虫

用于分析网站内容的函数库。

  • Apache Nutch:可用于生产环境的高度可扩展、可伸缩的网络爬虫。
  • Crawler4j:简单的轻量级爬虫。
  • JSoup:刮取、解析、操作和清理HTML。

高性能

与高性能计算有关的资源,包括集合以及很多具体功能的函数库。

安全

用于处理安全、认证、授权或会话管理的函数库。

  • Apache Shiro:执行认证、授权、加密和会话管理。
  • Spring Security:专注认证、授权和多维度攻击防护框架。
  • Cryptomator:在云上进行客户端跨平台透明加密。
  • Keycloak:为浏览器应用和RESTful Web Service提供SSO和IDM集成。
  • PicketLink:一个针对Java应用进行安全和身份认证管理的大型项目,简化了安全和认证管理流程。

Web框架

用于处理Web应用程序不同层次间通讯的框架。

  • Spring:旨在简化Java EE的开发过程,提供依赖注入相关组件并支持面向切面编程。
  • Spring Boot:微框架,简化了Spring新程序的开发过程。
  • GWT:GWT(Google Web Toolkit),一组Web开发工具集,包含在客户端将Java代码转为JavaScript的编译器、XML解析器、RCP API、JUnit集成、国际化支持和GUI控件。
  • PrimeFaces:JSF框架,提供免费版和带技术支持的商业版。
  • Apache Tapestry:基于组件的框架,使用Java创建动态的、健壮的、高度可扩展的Web应用程序。
  • Apache Wicket:基于组件的Web应用框架,与Tapestry类似带有状态显示GUI。
  • Grails:Groovy框架,旨在提供一个高效开发环境,使用约定而非配置,没有XML并支持混入(mixin)。
  • Play:基于 Akka 的一个轻量级、无状态、Web友好的架构。
  • Vaadin:基于GWT构建的事件驱动框架,使用服务端架构,客户端使用Ajax。
  • Ninja:Java全栈Web开发框架,非常稳固、快速和高效。
  • Ratpack:一组Java开发函数库,用于构建快速、高效、可扩展且测试完备的HTTP应用程序。

REST框架

用来创建RESTful服务的框架。

  • Jersey:JAX-RS参考实现。
  • RESTEasy:经过JAX-RS规范完全认证的可移植实现。
  • Dropwizard:偏向于自己使用的Web框架,用来构建Web应用程序,使用了Jetty、Jackson、Jersey和Metrics。
  • Swagger:Swagger是一个规范且完整的框架,提供描述、生产、消费和可视化RESTful Web Service。
  • Retrofit:一个Java类型安全的REST客户端。
  • Spark:受到Sinatra启发的Java REST框架。

ORM框架

处理对象持久化的API。

  • MyBatis:支持定制化 SQL、存储过程以及高级映射的优秀的持久层框架。
  • Apache Cayenne:为数据访问提供简单、静态的API,还包括用于处理数据库映射、DB逆向工程的GUI映射工具。
  • Ebean:支持快速数据访问和编码的ORM框架。
  • EclipseLink:支持许多持久化标准,JPA、JAXB、JCA和SDO。
  • Hibernate:广泛使用的持久化框架,其技术社区非常活跃。

测试

测试内容从对象到接口,涵盖性能测试和基准测试工具。

  • VisualVM:提供可视化方式查看运行中的应用程序信息。
  • JUnit:通用测试框架。
  • Apache JMeter:功能性测试和性能评测。
  • Arquillian:集成测试和功能行测试平台,集成Java EE容器。
  • AssertJ:支持流式断言提高测试的可读性。
  • JMH:JVM微基准测试工具。
  • Mockito:在自动化单元测试中创建测试对象,为TDD或BDD提供支持。
  • Selenium:为Web应用程序提供可移植软件测试框架。
  • Selenide:为Selenium提供精准的周边API,用来编写稳定且可读的UI测试。
  • TestNG:测试框架。

模版引擎

对模板中表达式进行替换的工具。

  • Thymeleaf:新一代模板引擎,支持XML,可完全取代JSP。
  • Apache Velocity:提供HTML页面模板、Email模板和通用开源代码生成器模板。
  • FreeMarker:通用模板引擎,不需要任何重量级或自己使用的依赖关系。
  • Jtwig:模块化、可配置和经过充分测试的模板引擎。
  • Handlebars.java:使用Java编写的模板引擎,逻辑简单,支持语义扩展(semantic Mustache)。

开发库

从基础层次上改进开发流程。

  • JRebel:商用软件,无需重新部署可即时重新加载代码及配置。
  • AspectJ:面向切面编程扩展,与程序无缝连接。
  • Auto:源代码生成器集合。
  • Lombok:代码生成器,旨在减少Java冗余代码。
  • DCEVM:通过修改JVM在运行时可无限次重定义已加载的类。
  • RxJava:使用JVM中可观察序列,创建异步、基于事件应用程序的函数库。
  • vert.x:JVM多语言事件驱动应用框架。
  • Spring Loaded:另一个JVM类重载代理。

JVM和JDK

目前的JVM、JDK实现。

  • OpenJDK:JDK的开源版本。
  • Avian:一个轻量级虚拟机和类库。
  • ParparVM:在Java中构建本机iOS应用程序的安全、简单、易用的方法。
  • Zulu OpenJDK:经过认证的与Java SE标准完全兼容JDK开源版本。

编译器

创建分析器、解释器和编译器的框架。

  • ANTLR:一个基于Java 开发的功能强大的语言识别工具,Antlr 以其简介的语法和高速的运行效率在这类工具中出类拔萃。
  • JFlex:Java编写的Java词法分析器。

字节码操作

操作Java字节码的函数库。

  • ASM:一个通用的Java字节码操作和分析框架。
  • Javassist:用于在Java中编辑字节码的类库。
  • CGlib:一个强大的、高性能和高质量的代码生成库,用于在运行时扩展JAVA类并实现接口。
  • Byte Buddy:一个代码生成和操作库,用于在Java应用程序运行时创建和修改Java类而无需编译器的帮助。

依赖注入

实现控制反转的函数库。

  • HK2:轻量级动态依赖注入框架。
  • Dagger2:编译期的注入框架,没有使用反射,主要用于Android开发。
  • Guice:轻量级注入框架,功能强大可与Dagger媲美。

工具类

通用工具类函数库。

  • Guava:集合、缓存、支持基本类型、并发函数库、通用注解、字符串处理、I/O等。
  • Apache Commons:提供各种用途的函数,比如配置、验证、集合、文件上传或XML处理等。
  • javatuples:正如名字表示的那样,提供tuple支持,尽管目前tuple的概念还有留有争议。

日志

记录应用程序的日志函数库。

  • Logback:Log4j原班人马作品,被证明是一个强健的日志函数库,通过Groovy提供了很多有意思的配置选项。
  • SLF4J:日志抽象层,需要与某个具体日志框架配合使用。
  • Apache Log4j 2:Log4j的升级版,相比Log4j 1.x 版本有了很大的性能提升,在提供了Logback所能提供的功能的同时还解决了Logback的架构下的固有问题。
  • Kibana:一个针对Elasticsearch的开源分析及可视化平台,用来搜索、查看交互存储在Elasticsearch索引中的数据。
  • Logstash:日志文件管理工具。

JSON

简化JSON处理的函数库。

  • Gson:将Java对象序列化为JSON及反向操作,使用时提供了很好的性能。
  • Jackson:与GSON类似,但如果需要频繁初始化Jackson库会带来性能问题。

序列化

用来高效处理序列化的函数库。

  • MessagePack:一种高效的二进制序列化格式。
  • FlatBuffers:序列化函数库,高效利用内存,无需解包和解析即可高效访问序列化数据。
  • Kryo:快速和高效的对象图形序列化框架。

文档处理

用来处理Office格式文档的函数库。

  • Apache POI:支持OOXML(XLSX、DOCX、PPTX)以及 OLE2(XLS, DOC or PPT)格式的文档。
  • documents4j:使用第三方转换器进行文档格式转换的API。
  • docx4j:创建和操作Microsoft Open XML(Word docx,Powerpoint pptx和Excel xlsx)文件的Java库。

PDF处理

用来帮助创建PDF文件的资源。

  • iText:一个易于使用的PDF函数库,用来编程创建PDF文件,注意,用于商业用途时需要许可证。
  • JasperReports:一个复杂的报表引擎。
  • DynamicReports:JasperReports的精简版。
  • Apache FOP:从XSL-FO创建PDF。
  • Apache PDFBox:用来创建和操作PDF的工具集。

图像处理

用来帮助创建、评估或操作图形的函数库。

  • Picasso:Android下载图像和图像缓存函数库。
  • ZXing:多种格式的一维、二维条形码处理函数库。

游戏开发

游戏开发框架。

  • jMonkeyEngine:支持现代3D开发的游戏引擎。
  • libGDX:全面的跨平台高级开发框架。
  • LWJGL:抽象了OpenGL、CL、AL等函数库的健壮框架。

GUI

用来创建现代图形用户界面的函数库。

  • SWT:Java开源小部件工具包。
  • JavaFX:Swing的继承者。
  • Scene Builder:JavaFX虚拟布局工具。

发布

使用本机格式分发Java应用程序的工具。

  • Launch4j:将JAR包装为小巧的Windows可执行文件。
  • packr:将程序JAR、资源和JVM打包成Windows、Linux和Mac OS X的本机文件。
  • Bintray:对二进制发布进行版本控制,可与Maven或Gradle配合使用。
  • IzPack:为跨平台部署建立授权工具。

其它

其它资源。

  • Design Patterns:实现并解释了最常见的设计模式。
  • Jimfs:内存文件系统。
  • LightAdmin:可插入式CRUD UI函数库,可用于快速应用开发。
  • OpenRefine:用来处理混乱数据的工具,包括清理、转换、使用Web Service进行扩展并将其关联到数据库。
  • RoboVM:Java编写原生iOS应用。

网站

值得关注的网站。

文章翻译自 akullpp Github