上个周末抽时间整理了一些阿里开源的一些 Java 开源项目,希望对大家有帮助!这篇文章收录的所有开源项目都是还在继续维护并且可以使用的。

虽然有部分项目不是那么”完美“,但是依然非常值得我们学习。

感谢阿里技术团队的小伙伴们为 Java 开源生态做的贡献!

Canal

Canal[kə'næl] 翻译过来是水道/管道/沟渠的意思,主要用于基于 MySQL 数据库增量日志解析,提供增量数据订阅和消费。

Canal 可以帮助我们实现 MySQL 和其他数据源比如 Elasticsearch、Kafka、RocketMQ 或者另外一台 MySQL 数据库之间的数据同步。Canal 的底层原理依赖 binlog,它会模拟 MySQL 主从复制的过程,解析 binlog 将数据同步到其他的数据源。

MySQL binlog(binary log 即二进制日志文件) 主要记录了 MySQL 数据库中数据的所有变化(数据库执行的所有 DDL 和 DML 语句)。因此,我们根据主库的 MySQL binlog 日志就能够将主库的数据同步到从库中。

更具体和详细的过程是这个样子的(图片来自于:《MySQL Master-Slave Replication on the Same Machine》[1]):

MySQL主从复制

  1. 主库将数据库中数据的变化写入到 binlog
  2. 从库连接主库
  3. 从库会创建一个 I/O 线程向主库请求更新的 binlog
  4. 主库会创建一个 binlog dump 线程来发送 binlog ,从库中的 I/O 线程负责接收
  5. 从库的 I/O 线程将接收的 binlog 写入到 relay log 中。
  6. 从库的 SQL 线程读取 relay log 同步数据本地(也就是再执行一遍 SQL )
  • Wiki : https://github.com/alibaba/canal/wiki 。
  • Github :https://github.com/alibaba/canal 。

EasyExcel

Java 解析、生成 Excel 常用的框架有 Apache poi、jxl ,但是这两个框架使用起来都不够优雅,并且非常耗内存严重时会导致内存溢出

怎么解决这个问题呢?

推荐你使用阿里开源的 EasyExcel。正如这个项目官网介绍的那样,这是一款快速、简单避免 OOM 的 java 处理 Excel 工具。

官方是这样介绍 EasyExcel的:

  • 官方文档 :https://www.yuque.com/easyexcel 。
  • Github :https://github.com/alibaba/easyexcel 。

Arthas

arthas

Arthas 是阿里开源的一个 Java 诊断工具,能够分析、诊断、定位 Java 应用问题。

Arthas能帮我们解决的一些问题

Arthas 把一些常用的 Java 诊断相关的功能封装起来了,提供简单的命令行操作,功能强大。

Arthas 底层用到了字节码编程相关的技术,简单看了一下源码,应该是基于 ByteBuddy。

ByteBuddy 是一款强大的 Java 字节码增强框架,它提供了一套统一易上手的 Api,简化了字节码编码的学习和使用难度。Byte Buddy 成熟稳定,性能也还不错。像咱们平常经常使用 Mockito,Hibernate,Jackson 等知名框架都使用了 Byte Buddy。

Arthas 提供了详细的在线教程供我们学习,非常赞!在线教程地址:https://arthas.aliyun.com/doc/arthas-tutorials.html?language=cn

Arthas在线教程

  • 官网 :https://arthas.aliyun.com/zh-cn/ 。
  • Github :https://github.com/alibaba/arthas 。

相关阅读:

  • 使用 Arthas 排查 SpringBoot 诡异耗时的 Bug
  • 阿里问题定位神器 Arthas 的骚操作,定位线上 BUG,超给力

FastJson

FastJson 是阿里的开源一个 JSON 解析库,其底层使用了 ASM 来动态生成类。Fastjson 的速度非常快,不过,快的同时也带来一些潜在的安全问题。

FastJson 几乎是作者温少大佬一个人开发和维护的,真心厉害!佩服!

我这里简单对 Nacos 官网对 Nacos 的介绍总结了一下:

看到网上有很多人诟病 Fastjson 的漏洞问题,都是做技术的,希望大家也多给予一些理解吧!

  • Wiki :https://github.com/alibaba/druid/wiki/常见问题[2]
  • Github : https://github.com/alibaba/fastjson

Druid

Druid 是阿里巴巴开发的号称为监控而生的数据库连接池。和 FastJson 类似,Druid 几乎也是作者温少大佬一个人开发和维护的。

Github 地址:https://github.com/alibaba/druid 。

Spring Cloud Alibaba 相关

Sentinel

Sentinel 是阿里巴巴体提供的面向分布式服务架构的流量控制组件,主要以流量为切入点,提供 流量控制熔断降级系统自适应保护等功能来保护系统的稳定性和可用性。

  • 官方文档https://sentinelguard.io/zh-cn/docs/introduction.html[3] 。
  • Github :https://github.com/alibaba/Sentinel 。

Nacos

Nacos 是一个更易于构建云原生应用的动态服务发现、配置管理和服务管理平台。

我这里简单对 Nacos 官网对 Nacos 的介绍总结了一下:

  1. Nacos 主要用于发现、配置和管理微服务:Nacos 是 Spring Cloud Alibaba 提供的服务注册发现组件,类似于 Consul、Eureka。并且,提供了分布式配置管理功能。
  2. Nacos 名字的含义 :Na 即是 Naming(注册中心),co 即是 Configuration(配置管理),最后的 s 即是 Service。

Nacos 的关键特性包括:

  • 服务发现和服务健康监测
  • 动态配置服务 :提供能很多开箱即用的配置管理特性比如一键回滚配置、版本跟踪、金丝雀发布等等。并且,内置了简洁易用的 UI。
  • 动态 DNS 服务 :动态 DNS 服务支持权重路由,让您更容易地实现中间层负载均衡、更灵活的路由策略、流量控制以及数据中心内网的简单 DNS 解析服务。
  • 服务及其元数据管理
  • ......

Nacos 生态图如下,可以看出 Nacos 无缝支持一些主流的开源生态如 Spring Cloud、Dubbo、K8S 等等。

  • 官网:https://nacos.io/zh-cn/index.html 。
  • Github :https://github.com/alibaba/nacos 。

RocketMQ

RocketMQ 是一款高性能、高可靠、高实时、分布式的消息队列,由阿里巴巴团队开发,在 2016 年底贡献给 Apache 并且顺利成为了 Apache 的一个顶级项目。

  • 官网 :https://rocketmq.apache.org/ 。
  • Github :https://github.com/apache/rocketmq 。

Dubbo

Apache Dubbo |ˈdʌbəʊ| 是一款高性能、轻量级的开源 Java RPC 框架。

根据 Dubbo 官方文档的介绍,Dubbo 提供了六大核心能力

  1. 面向接口代理的高性能 RPC 调用。
  2. 智能容错和负载均衡。
  3. 服务自动注册和发现。
  4. 高度可扩展能力。
  5. 运行期流量调度。
  6. 可视化的服务治理与运维。

Dubbo提供的六大核心能力

简单来说就是:Dubbo 不光可以帮助我们调用远程服务,还提供了一些其他开箱即用的功能比如智能负载均衡。

相关阅读:1w+字的 Dubbo 面试题/知识点总结!(2021 最新版) 。

  • 官方文档:https://dubbo.apache.org/zh/ 。
  • Github :https://github.com/apache/dubbo 。

Seata

Seata 是一款开源的分布式事务解决方案,致力于在微服务架构下提供高性能和简单易用的分布式事务服务。

数据库事务可以保证多个对数据库的操作(也就是 SQL 语句)构成一个逻辑上的整体。构成这个逻辑上的整体的这些数据库操作遵循:要么全部执行成功,要么全部不执行 。

但是,微服务架构下,一个系统被拆分为多个小的微服务。每个微服务都可能存在不同的机器上,并且每个微服务可能都有一个单独的数据库供自己使用。这种情况下,一组操作可能会涉及到多个微服务以及多个数据库。

这个时候单单依靠数据库事务就不行了!我们就需要引入 分布式事务 这个概念了!

实际上,除了我们上面提到的 服务拆分(微服务) 的场景,像 数据库水平拆分(分库分表) 这种场景的话也是需要引入分布式事务的。

一言蔽之,分布式事务的终极目标就是保证系统中多个数据库中的数据的一致性!

分布式事务的解决方案有很多,比如:2PC3PCTCC本地消息表MQ 事务Saga 等等。

  • 官网 :http://seata.io/zh-cn/ 。
  • Github :https://github.com/seata/seata 。

相关阅读:

  • 阿里终面:分布式事务原理 :1.4 w 字,25 张图让你彻底掌握分布式事务原理。
  • Seata 分布式事务实践和开源详解 | GIAC 实录[4] :这篇文章是蚂蚁金服技术专家、分布式事务 Seata 发起者之一张森(花名:绍辉)在 GIAC 全球互联网架构大会的分享。文章内容详细介绍了分布式事务问题产生原因以及蚂蚁金服的应对措施(分布式事务 Seata 的 AT、TCC、Saga 和 XA 四种模式)。

P3C

P3C 项目包含了阿里巴巴 Java 开发手册(整合了阿里巴巴技术团队多年来的最佳编程实践)以及配套的 IDE 插件。

  • P3C-PMD :https://github.com/alibaba/p3c/tree/master/p3c-pmd
  • IDEA 插件 :https://github.com/alibaba/p3c/tree/master/idea-plugin
  • Eclipse 插件 :https://github.com/alibaba/p3c/tree/master/eclipse-plugin

这里我们以 IDEA 插件为例。

对应的 IDEA 插件名称是 Alibaba Java Code Guidelines。

安装完成之后建议将与语言替换成中文,提示更加友好一点。

根据官方描述:

目前这个插件实现了开发手册中的的 53 条规则,大部分基于 PMD 实现,其中有 4 条规则基于 IDEA 实现,并且基于 IDEA Inspection 实现了实时检测功能。部分规则实现了 Quick Fix 功能,对于可以提供 Quick Fix 但没有提供的,我们会尽快实现,也欢迎有兴趣的同学加入进来一起努力。目前插件检测有两种模式:实时检测、手动触发。

你还可以手动配置相关 inspection 规则:

这个插件会实时检测出我们的代码不匹配它的规则的地方,并且会给出修改建议。比如我们按照下面的方式去创建线程池的话,这个插件就会帮我们检测出来,如下图所示。

Alink

Alink 是基于 Flink 的通用算法平台,由阿里巴巴计算平台 PAI 团队研发。Alink 已在阿里巴巴内部支持了众多的应用场景,并在 2019 年 11 月的 Flink Forward Asia 大会上宣布开源。

Alink 提供了一系列算法,可以帮助处理各种机器学习任务比如模型选择和调参、个性化推荐、异常检测。

Alink 覆盖了机器学习核心的三类算法:分类算法、聚类算法、回归算法。并且,还包括联规则和协同过滤算法、相似度算法等数据挖掘方面算法。

Alink 开源算法列表

  • Github :https://github.com/alibaba/Alink 。
  • 官方文档 :https://www.yuque.com/pinshu/alink_doc
  • 使用指南:https://www.yuque.com/pinshu/alink_guide
  • Alink 插件下载器 :https://www.yuque.com/pinshu/alink_guide/czg4cx

COLA

COLA 是 Clean Object-Oriented and Layered Architecture 的缩写,代表“整洁面向对象分层架构”。COLA 可以帮助开发人员快速实践 DDD 落地的项目架构。

Github : https://github.com/alibaba/COLA 。

相关阅读:COLA 4.0:应用架构的最佳实践[5]

TestableMock

一款极简风格的 Mock 测试工具。无需初始化,不挑服务框架,甭管要换的是私有方法、静态方法、构造方法还是其他任何类的任何方法,也甭管要换的对象是怎么创建的。写好 Mock 定义,加个@MockMethod注解,一切统统搞定。

  • Github : https://github.com/alibaba/testable-mock
  • 文档 :https://alibaba.github.io/testable-mock/
  • 国内文档镜像 :http://freyrlin.gitee.io/testable-mock/

相关阅读: 史上最轻量!阿里新型单元测试 Mock 工具开源了

Compileflow

一个非常轻量、高性能、可集成、可扩展的流程引擎,淘宝工作流TBBPM引擎之一。

Compileflow 专注于纯内存执行,无状态的流程引擎,通过将流程文件转换生成java代码编译执行,简洁高效。当前是阿里业务中台交易等多个核心系统的流程引擎。

  • Github :https://github.com/alibaba/compileflow 。
  • 官方 Demo : https://github.com/compileflow/compileflow-demo 。
  • 基于 IntelliJ IDEA 流程可视化插件 : https://github.com/alibaba/compileflow-idea-designer

小伙伴们有兴趣想了解内容和更多相关学习资料的请点赞收藏+评论转发+关注我,后面会有很多干货。我有一些面试题、架构、设计类资料可以说是程序员面试必备!所有资料都整理到网盘了,需要的话欢迎下载!私信我回复【999】即可免费获取

阿里巴巴开源的15个顶级Java项目相关推荐

  1. 阿里开源的15个顶级Java项目!!!

    Canal Canal[kə'næl] 翻译过来是水道/管道/沟渠的意思,主要用于基于 MySQL 数据库增量日志解析,提供增量数据订阅和消费. Canal 可以帮助我们实现 MySQL 和其他数据源 ...

  2. 阿里开源的15个顶级Java项目

    上个周末抽时间整理了一些阿里开源的一些 Java 开源项目,希望对大家有帮助!这篇文章收录的所有开源项目都是还在继续维护并且可以使用的. 虽然有部分项目不是那么"完美",但是依然非 ...

  3. 15个顶级Java多线程面试题及答案

    转载自  15个顶级Java多线程面试题及答案 在任何Java面试当中多线程和并发方面的问题都是必不可少的一部分.如果你想获得更多职位,那么你应该准备很多关于多线程的问题. 他们会问面试者很多令人混淆 ...

  4. 15个顶级Java多线程面试题及回答(高级java工程师)

    Java 线程面试问题 在任何Java面试当中多线程和并发方面的问题都是必不可少的一部分.如果你想获得任何股票投资银行的前台资讯职位,那么你应该准备很多关于多线程的问题.在投资银行业务中多线程和并发是 ...

  5. 阿里开源的10个神级项目

    前言 最近趁着国庆节放假休息,特地整理了一下,阿里巴巴开源的10款神级项目. 这些开源项目中的绝大多数,我都在实际工作中用过,或者有同事用过.确实挺不错,挺有价值的,现在推荐给大家.   1. Dru ...

  6. 强烈推荐 | 阿里开源的10个神级项目

    前言 最近趁着国庆节放假休息,特地整理了一下,阿里巴巴开源的10款神级项目. 我的个人技术博客:https://susan.net.cn 这些开源项目中的绝大多数,我都在实际工作中用过,或者有同事用过 ...

  7. 强烈推荐,阿里开源的11个神级项目

    本 文介绍 阿里巴巴开源的11款神级项目, 这些开源项目中的绝大多数,我都在实际工作中用过,或者有同事用过. 确实挺不错 ,挺有 价值的,现在推荐给大家. 1. Druid Druid自称是Java语 ...

  8. 阿里巴巴开源项目汇总-(JAVA)

    来源:https://segmentfault.com/a/1190000017346799 1.分布式应用服务开发的一站式解决方案 Spring Cloud Alibaba Spring Cloud ...

  9. 阿里巴巴开源的java项目

    1.分布式应用服务开发的一站式解决方案 Spring Cloud Alibaba Spring Cloud Alibaba 致力于提供分布式应用服务开发的一站式解决方案.此项目包含开发分布式应用服务的 ...

  10. Arthas使用教程 阿里巴巴开源项目、史上最强java线上诊断工具

    什么是 Arthas 摘录一段官方 Github 上的简介 Arthas 是Alibaba开源的Java诊断工具,深受开发者喜爱. 当你遇到以下类似问题而束手无策时,Arthas 可以帮助你解决: 这 ...

最新文章

  1. Python 判断当前数值的类型(比如x=10 获取x的类型)
  2. Http协议中的Content-Length属性
  3. 二分搜索 POJ 3273 Monthly Expense
  4. Screenshot of a full element in Selenium C#
  5. MPEG原理分析及MPEG音频编码器的调试
  6. Linux -- 进程或线程独占CPU
  7. pytorch中CrossEntropyLoss和NLLLoss的区别与联系
  8. Python接口自动化之requests请求封装
  9. 【VMware vSAN 6.6】5.4.vSAN 配置提示:vSAN硬件服务器解决方案
  10. “手把手撕LeetCode题目,扒各种算法套路的裤子”
  11. 浅谈游戏被唾弃的原因
  12. 数据结构实验——就餐人数最多的时间段
  13. PS 导入笔刷和导入字体和导入滤镜
  14. linux驱动管道,Xilinx Linux 如何理解V4L2的管道驱动程序
  15. Unity打造科技风智慧城市夜景教程
  16. java native函数库_Java 层调用 Native 层函数的两种方式
  17. 含并行连结的网络(GoogLeNet)
  18. 时空旅行的可能性(无聊研究社)
  19. 人工智能python编程具体做什么_人工智能主要学习什么编程?
  20. 广州大学数据库实验报告_广州大学学生实验报告.doc

热门文章

  1. 在Codesys用ST语言基于数组实现栈LIFO数据结构详细说明+代码实例
  2. FR-报表应用-分组报表-动态显示N个分组
  3. 使用Fiddler快速保存微信视频号上的视频
  4. 阿里云【云计算7天实践训练营】新人路线-class6学习笔记
  5. Annoying Present CodeForces - 1009C
  6. 安卓版本与adb的问题
  7. php dingo和jwt,DingoApi 中使用 JWT
  8. 程序员的桌面画风竟然是酱紫的!
  9. 聊聊HotSpot VM的Native Memory Tracking
  10. C++实现LZ77压缩算法