代码改变世界

主流的开源协议(MIT,Apache,GPL v2/v3) - 实践

2025-09-19 17:29  tlnshuju  阅读(317)  评论(0)    收藏  举报

“开源协议选择指南”的流程图
在这里插入图片描述

flowchart TD
A[开始选择开源协议] --> B{是否要求修改后必须开源?(是否具有 传染性?)};
B -- 是(强Copyleft) --> C{GPL家族};
C --> C1[GPL v2/ v3要求派生代码必须使用相同许可证开源];
B -- 否(宽松/弱Copyleft)--> D{是否需要专利授权?};
D -- 是 --> E{Apache 2.0宽松且提供明确的专利授权};
D -- 否 --> F{MIT最宽松,仅要求保留版权声明};
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 Apache 2.0)。就是: 搜索和分析引擎(在 7.11 版本之后,其部分功能使用了 Elastic License 或 SSPL,但核心和历史版本

  • 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, jQueryAndroid, Kafka, KubernetesLinux Kernel, WordPress, Git