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

发布于:2025-09-09 ⋅ 阅读:(22) ⋅ 点赞:(0)

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

flowchart TD
    A[开始选择开源协议] --> 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

网站公告

今日签到

点亮在社区的每一天
去签到