Java 技术分类汇总(持续更新中)

技术选型原则

业务驱动技术,技术的出现是为了更好地支撑业务,离开业务谈技术都是耍流氓。选型维度可参考以下几方面:框架成熟度、社区热度、可维护性、开发效率、运行效率、成功案例、文档丰富程度、学习曲线。通过以下不同技术的组合,可以打磨出高可用、高性能、高并发、高扩展的系统应用。

常用类库、框架

SQL 优化:P6Spy

Bean 映射工具:Dozer

Java 诊断工具:Arthas

Web 爬虫:Webmagic、Jsoup

Binlog 解析工具:Maxwell、Canal

数据导出:POI、EasyPOI、EasyExcel

动态代理:Byte Buddy、Cglib、ASM、Javassist、JDK 动态代理

代码混淆:Zelix KlassMaster

代码测试:Mockito、Jacoco

Reids 客户端:Jedis、Lettuce、Redisson

网络通信:Netty、Mina、Grizzly

权限安全:Shiro、Spring Security

搜索引擎:Lucene、Solr、ElasticSearch、Redis Stack(RediSearch)

数据库连接池:C3P0、DBCP、Druid、HikariCP、BeeCp

HTTP 请求:OkHttp、Retrofit、Apache HttpClient

限流:Bucket4j、RateLimitJ、RateLimiter(Guava)

模版引擎:FreeMarker、Thymeleaf、Velocity、Beetl、Enjoy

工具库:Guava、Apache Commons、Joda Time、Hutool

工作流:Activiti、JBPM、Flowable、Bonita 、Apache Airflow

API 文档:Spring REST Docs、Knife4j、Swagger2、OpenAPI3

响应式编程:RxJava、Reactor、Vert.x、Akka Streams、Ratpack

序列化:Jackson、Gson、FastJson、ProtoBuf、Thrift、Hessian、Kryo、FST

缓存:Ehcache、Caffeine 、Spring Cache、Guava Cache、JetCache、Hazelcast、Infinispan、J2Cache

ORM 框架:JPA(EclipseLink、Apache OpenJPA)、Hibernate、MyBatis、MyBatis-Plus、TKMybatis、jOOQ、BeetlSQL、APIJSON

基础开发框架:Struts2、Spring、Spring MVC、Spring WebFlux、JFinal

分布式、微服务、云原生

微服务:Spring Boot、Spring Cloud、Spring Cloud Alibaba、Quarkus、Helidon、Micronaut、Microprofile

分布式锁:Redission、ZooKeeper、Chubby

RPC 框架:gRPC、Thrift、Dubbo、Sofa-RPC、Motan、ZBUS、HSF

服务监控:Spring Boot Admin、Prometheus、Grafana、AlertManager、Metrics、Cacti、Zabbix、Nagios、Cat、Atlas、Spectator、Open Falcon、New Relic

消息队列:Kafka、RabbitMQ、ActiveMQ、RocketMQ、ZeroMQ、RedisMQ、Beanstalkd、ZUBS

服务注册与发现:Eureka、Zookeeper、Consul、Etcd3、Nacos、SOFARegistry、Istio

分布式配置中心:Spring Cloud Config、Zookeeper、Consul、Etcd3、Nacos、Apollo、Disconf、Chef

分布式任务调度:ElasticJob、XXL-JOB、PowerJob、Saturn、K8S Job、DolphinScheduler

分布式调用链路追踪:Micrometer、Sleuth、Zipkin、Brave、SkyWalking、OpenTracing、OpenCensus、OpenTelemetry、、Pinpoint、Jaeger、Dapper、JVM-SANDBOX

分布式文件系统:HDFS、FastDFS、MinIO、TFS、GlusterFS、Ceph、MooseFS

服务调用失败重试:Spring Retry、Hystrix、OpenFeign、Resilience4J、Sentinel

服务路由(网关):Gateway、Zuul、Kong、Nginx、OpenResty、ShenYu、Envoy、Higress、Linkerd、Tyk、Orange

服务熔断、服务降级:Hystrix、Sentinel、Resilience4J、Enovy

数据库中间件:MyCat、ShardingSphere、Canal、Cobar、Atlas、DBProxy、ProxySQL、OneProxy、Heisenberg、CDS、DDB、Amoeba、Vitess、SOFA、TongWeb

数据库:MySQL、PostgreSQL、MongoDB、HBase、Ignite、Oracle、DB2、SQL Server、Cassandra、MinIO、InfluxDB

内存数据库:Redis、Memcached、Tair、Couchbase

嵌入式数据库:SQLite、H2、Derby、HSQL

数据库迁移:Flyway、Liquibase

日志采集处理:Kafka、Flume、Logstash、Filebeat、Fluentd、Graylog、Splunk Forwarder、Apache NiFi、Heka

大数据技术:Spark 生态圈、Hadoop、HDFS、Zookeeper、Yarn、Hive、Hbase、Storm、Flume、Sqoop、Impala、ClickHouse、Flink

大数据任务调度:Azkaban、Oozie、Airflow、DolphinScheduler

分布式事务:Seata、Hmily、TxLcn

分布式全局唯一 ID:SnowFlake、UidGenerator、Leaf

分布式系统其他基础技术:CAS 单点登录、分布式 Session

分布式数据库其他基础技术:数据库集群、主从同步、读写分离、分库分表、分片分区

云原生基础技术:Envoy、Istio、Kubernetes、Dapr、eBPF、MOSN、GraalVM

开源 JDK:OpenJDK、Alibaba Dragonwell、Amazon Corretto、Azul Zulu、Tencent Konna

运维、编译构建、持续集成、虚拟化

自动化运维平台:Ansible

编译构建:Maven、Gradle、Ant、Bazel

Linux 系统:CentOS、Debian、Ubuntu、SUSE

持续集成:Jenkins、Hudson、Bamboo、Spinnaker

Web 服务器:Apache、Tomcat、Jetty、Undertow、Liberty、Weblogic、Websphere、WildFly、GlassFish、TomEE、Resin、Payara

虚拟化方案:KVM、XEN、Docker、VirtualBox、VMware WorkStation、VMware ESXi、Hyper-V

容器化技术:Docker、Swarm、Machine、Compose、Kubernetes、Mesos(Day2IQ)、Rancher、Podman、K3S、Skopeo、Buildah、Rancher2、Portainer、Proxmox

负载均衡、反向代理、缓存服务器:LVS、Nginx、OpenResty、Tengine、Squid、Varnish、Caddy、Envoy、HAProxy、Keepalived、Heartbeat

协同办公、知识管理、代码审核

代码审核:Gerrit、GitLab

知识管理(WiKi):Confluence