主流的开源协议(MIT,Apache,GPL v2/v3)
文章目录
- 1. MIT 协议 (MIT License)
- 2. Apache 2.0 协议 (Apache License 2.0)
- 3. GPL v2 协议 (GNU General Public License v2)
“开源协议选择指南”的流程图
flowchart TDA[开始选择开源协议] --> B{是否要求修改后必须开源?<br>(是否具有 传染性?)};B -- 是(强Copyleft) --> C{GPL家族};C --> C1[GPL v2/ v3<br>要求派生代码必须使用相同许可证开源];B -- 否(宽松/弱Copyleft)--> D{是否需要专利授权?};D -- 是 --> E{Apache 2.0<br>宽松且提供明确的专利授权};D -- 否 --> F{MIT<br>最宽松,仅要求保留版权声明};B -- 否(宽松) --> G{是否要求与闭源软件兼容?};G -- 是 --> E;G -- 否 --> F;
1. MIT 协议 (MIT License)
核心特点:极其宽松,几乎没有任何限制。你只需要在副本中包含原软件的版权和许可声明,就可以自由地使用、复制、修改、合并、发布、分发、再许可和/或销售软件。对商业应用极其友好。
代表性项目:
jQuery: 经典的前端 JavaScript 库。
React: Facebook 推出的前端 UI 框架(注意:React 之前使用 BSD+Patents 条款,后改为 MIT)。
Ruby on Rails: 一套高效的 Web 应用开发框架。
Vue.js: 渐进式 JavaScript 框架(其核心在早期使用 MIT,现在整个项目生态也主要基于 MIT)。
Node.js: JavaScript 运行时环境。
Laravel: 流行的 PHP Web 框架。
.NET Core: Microsoft 推出的跨平台开发框架。
XWindow System: UNIX/Linux 系统上的图形窗口系统。
2. Apache 2.0 协议 (Apache License 2.0)
核心特点:商业友好但比 MIT 更严谨。它除了提供和 MIT 类似的自由权利外,还明确提供了专利授权,并要求对修改过的文件提供明显的更改说明。它防止了“专利偷袭”,同时也不要求衍生代码开源。
代表性项目:
-
Apache 基金会项目:
- Apache HTTP Server (Web 服务器)
- Apache Kafka (分布式消息队列)
- Apache Hadoop (大数据框架)
- Apache Spark (大数据处理引擎)
- Apache Tomcat (Java Web 容器)
-
Android: 谷歌的移动操作系统(其大部分代码)。
-
Kubernetes: 容器编排系统。
-
TensorFlow: Google 的机器学习框架。
-
Elasticsearch: 搜索和分析引擎(在 7.11 版本之后,其部分功能使用了 Elastic License 或 SSPL,但核心和历史版本是 Apache 2.0)。
-
Swift: Apple 开发的编程语言。
-
Flutter: Google 推出的跨平台 UI 工具包。
一句话总结: 和 MIT 一样宽松,但多了专利保护,更安全。
3. GPL v2 协议 (GNU General Public License v2)
具有“传染性”的强 Copyleft 协议。
- 特点: 强 Copyleft(著佐权) 协议,具有“病毒式”的传染性。
- 核心要求:
1、如果你的项目包含了或者修改了GPL 授权的代码,那么你的整个项目必须也以 GPL 协议开源。
2、必须提供源代码。
3、所有基于 GPL 代码的衍生作品也必须使用 GPL 协议。 - “传染性”体现: 这意味着你不能将 GPL 授权的代码用于你的闭源商业软件中。只要你用了,你的软件整个都必须变成开源的。
代表性项目:
GPL v2:
- Linux Kernel: 最著名的操作系统内核,是 GPL v2 的标杆。
- Git: 分布式版本控制系统(由 Linus Torvalds 开发)。
- MySQL: 关系型数据库(Oracle 旗下,同时提供商业许可)。
- WordPress: 世界上最流行的内容管理系统(CMS)。
- VLC media player: 功能强大的开源媒体播放器。
- GIMP: GNU 图像处理程序,类似 Photoshop。
GPL v3 (或 v2/v3 双许可):
- GCC: GNU 编译器集合。
- GDB: GNU 项目调试器。
- Bash: GNU 的 Bourne-Again Shell。
- LGPL (GPL 的宽松版) 的代表:
- GLib & GTK: Linux 桌面环境(如 GNOME)的基础库和图形组件库。
- 7-Zip: 文件压缩软件。
- Audacity: 音频编辑软件。
一句话总结: 用了我的代码,你的代码也必须开源。
特性 | MIT 协议 | Apache 2.0 协议 | GPL (v2/v3) 协议 |
---|---|---|---|
核心哲学 | 最大限度的自由 | 商业友好,明确专利授权 | Copyleft,保障下游用户自由 |
要求开源修改 | 否 | 否 | 是(整个衍生作品) |
专利授权 | 隐性/无明确条款 | 有,明确条款 | 有(v3 更明确) |
商标使用 | 禁止 | 禁止 | 禁止 |
应对硬件限制 | 无 | 无 | GPL v3 明确禁止 (Anti-Tivoization) |
商业友好度 | 极高 | 极高 | 低(要求代码开源,与专有软件不兼容) |
典型项目 | Node.js, React, jQuery | Android, Kafka, Kubernetes | Linux Kernel, WordPress, Git |