这篇文章对于我们做技术选型以及技术学习都有极强的指导性作用,建议收藏! 原创不易,若有帮助,欢迎点赞!
开源安全基金会(OpenSSF)发布了 Github 上一些热门开源项目的关键性评分数据。相比于项目的 Star 数量来说,这个关键性评分的含金量更高、更能反应项目的价值。
并且,统计数据是按照编程语言来划分的。涵盖的编程语言非常广,像 Java、C、C 、Go、JS、Php、Python 这些比较火的编程语言都在其中。
对于每一个项目,OpenSSF 就会根据一定的规则给其一个关键性评分。这样的话,关键性评分的计算规则就非常重要了!
下面这些参数决定了开源项目的关键性评分。并且,这些参数之间的权重也不一样。
created_since
:项目创建时间(单位:月)updated_since
: 最近一次更新项目的时间(单位:月)contributor_count
: 项目贡献者数量org_count
: 项目的贡献者所属的不同开源组织的数量commit_frequency
: 项目去年平均每周提交次数recent_releases_count
: 项目去年发行的版本数量closed_issues_count
: 项目在过去 90 天里关闭的 issue 数量。updated_issues_count
: 项目在过去 90 天里更新的 issue 数量。comment_frequency
: 项目在过去 90 天里每个 issue 的平均评论数量dependents_count
: 项目提交消息中提及的项目数
有了参数之后,我们根据对应的算法/规则即可计算出项目的关键性评分(0~1 之间)。
计算规则的话,小伙伴们可以在项目首页找到。项目地址:https://github.com/ossf/criticality_score 。
我这里简单带着小伙伴们看下 Java 项目的情况。
对应编程语言的统计数据下载地址:https://commondatastorage.googleapis.com/ossf-criticality-score/index.html 。
对于 Java 后端开发来说,项目的前 15 名中,大家最熟悉的莫过于下面这几个项目:
- Gradle:对比 Maven,Gradle 同样是一款非常好用的项目构建工具 。大部分小伙伴的客观印象是 Gradle 只在安卓项目上用的比较多,实际并不是。关于 Gradle 的使用方法可以看这篇文章:《说实话,用完 Gradle 之后,有点嫌弃 Maven 了。贼好用!》
- Spring Boot :Java 后端开发领域杀手锏级别的框架,只要你是 Java 后端开发,你就离不开它!非常好用!生态也非常棒!
- JDK :这里指的是 OpenJDK。Oracle JDK 是 OpenJDK 的一个实现,并不是完全开源的
- Jenkins :一款基于 Java 开发的持续集成工具,避免了我们手动进行 CI/CD 的工作。
- Netty :我在前面的文章就提过:但凡涉及到网络通信就必然必然离不开网络编程。Netty 目前作为 Java 网络编程最热门的框架,毫不夸张地说是每个 Java 程序员必备的技能之一。如果你要学习 Netty 的话,可以看看开源的 Netty 入门教程:https://github.com/Snailclimb/netty-practical-tutorial 。
- PMD :PMD是一款常用的程序代码检查工具。我们在项目中一般会集成它来对自己提交的代码做一层保障。
我们看了关键性评分最高的几个项目之后,再来看看有关技术选型的问题。
Spring Security VS Shiro
Spring Security 的关键评分位列所有 Java 项目的第 29 位。很遗憾的是,Shiro 并未上榜。
Spring Security 是 Spring 全家桶中非常强大的一个用来做身份验证以及权限控制的框架,我们可以轻松地扩展它来满足我们当前系统安全性这方面的需求。
Spring Security 背靠 Spring 生态,可谓是有一个强大的后盾。
虽然,相比于 Shiro 来说,Spring Security 的学习曲线更陡峭。但是,从生态等方面来说,Spring Security 依然是你做身份验证以及权限控制时的首选框架。
Fastjson vs Jackson
Fastjson 和 Jackson 两者都是比较常见的 Java 开源 JSON 解析库。
从 Star 数量来看的话,Fastjson 最多, Jackson 的低了很多。但是,关键性评分 Jackson 领先了很多,这个也是在我的意料之中。
主要也是因为 Fastjson 的代码质量以及设计更差,并且,经常被爆出有安全漏洞(设计问题)。虽然 Fastjson 在速度方面稍稍取胜,但是,差别和 Jackson 是不太明显的。
Spring MVC 默认采用 Jackson 解析 Json 也是有它的道理, 肯定不是 Spring 的那群巨佬拍个桌子就能决定的。
综上,我更推荐使用 Jackson 作为项目的 JSON 解析库。
Flyway vs Liquibase
Flyway 和 Liquibase 两者都是比较常见的数据库迁移工具。
Flyway 的关键评分位列所有 Java 项目的第 70 位,Liquibaseo 未上榜。
Guava vs Hutool
Guava 和 Hutool 两者都是目前非常好用的 Java 第三方工具类库。Guava 是 google 开源的,Hutool 是纯国产。
Guava 的关键性评分位列所有 Java 项目的第 78 位,而 Hutool 位于第 196 位。
相关文章:
- 我在这篇《不要重复造轮子?提高生产效率!3 个常用的开源工具库分享》 文章中推荐过 Hutool。
- 这篇文章《Guava - 拯救垃圾代码,写出优雅高效,效率提升 N 倍》 介绍了 Guava 的基本使用,
ShardingSphere vs MyCat
ShardingSphere (包括 Sharding-JDBC、Sharding-Proxy 和 Sharding-Sidecar ) 和 MyCat 两者都是常用分布式数据库中间件,分库分表等场景都会用到。
ShardingSphere 项目是当当捐入 Apache 的,目前主要由京东数科的一些巨佬维护。Mycat 是基于阿里 Cobar 演变而来。
ShardingSphere 的关键评分位列所有 Java 项目的第 72 位,MyCat 并为上榜。
这也是意料之中的事情了,毕竟 ShardingSphere 的生态体系更加完善,社区更加活跃,文档更加完善,更新和发布也更加频繁。从任何角度来说,你都没有理由选择 MyCat 。
推荐?: Github掘金计划:Github上的一些优质项目搜罗
推荐?:啪地一下,很快啊!已经 一年了!
我是Guide哥,Java后端开发,拥抱开源,喜欢烹饪,自由的少年。一个喜欢读者面试经验的技术人。我们下期再见!