GPL 是 GNU's General Public License 的缩写,翻译成中文叫 GNU 的通用公共许可证,是最受欢迎的开源许可证之一。它由理查德·斯托曼(Richard Stallman)创建,目的是保护 GNU 软件免于被专有,是基于他「版权向左(copyleft)」理念的一种实现。
01
什么是版权向左?
版权向左(copyleft)规定在未经版权所有者的许可下将限制使用、修改和分享创作品的权利。当作者在版权向左许可证下发布程序时,他对该作品的版权提出主张,并声明他人只要保持互惠义务,便可获使用、修改与分享该作品之授权。
这意味着,任何基于 GPL 组件编写的软件都必须作为开源发布。其结果是,任何 GPL 开源组件(不论其在整个代码所占的比例是多少),只要你在你的软件中使用了,你的软件就必须发布完整的源码以及修改和分发整个代码的权利。
02
GPL 许可证的条款与条件是什么?
如果你在软件中有使用 GPL 组件,则你的整个软件都会被视为「基于 GPL 的作品」,因此:
你无权对该软件主张专利或版权。此外,你有义务显式地进行版权声明(copyright notice),完整的 GPL 声明,以及 GPL 的副本。
不允许你更改许可证或引入其他条款和条件。
你有互惠义务,这意味着你必须释出源代码,以及关于修改和再分发整个代码的所有权利。
03
GPL 是否是强制性的?
GPL 本质上是版权许可(copyright license),因此是强制性的。GPL 软件的版权持有者可以选择对软件的分发或衍生作品强制使用 GPL。
例如,FSF 在许多 GNU 系统上拥有版权,比如 GNU Compiler Collection。作为版权持有者,如果该软件的版权发生侵权,那么它可以强制执行 GPL 的 copyleft 的要求。
04
是否可以出售 GPL 的软件或代码?
是的。GPL 许可证允许用户出售原始软件和经修改后的软件。这也许会造成混淆,但自由软件(free software)中的所谓「自由」,是指自由(freedom),而不是免费。正如理查德·斯托曼所解释的,自由软件的意思是「自由讨论」,而不是「免费啤酒」。
但如果有人付费购买了你的程序,则 GPL 允许 TA 自由地发布这个软件,不管是免费的还是付费的。
05
GPL 是安全的吗?
是的。GPL 与代码的安全性无关,它只是用于控制其使用与分发的许可证。实际上,正如我们以前所讨论过的,开源软件有时可能会比专有软件更安全,因为有更多的人参与到其中检查与修复问题。
06
GPL 许可证是否要求释出修改后的源码?
GPL 只要求你在发布修改后的程序之后,才需要释出修改后的源码。如果你把修改后的程序源码供个人使用,那么就不需要发布它的源代码。但是,如果把修改后的程序公开发布,那么其对应的源码也必须公开。
07
GPLv2 与 GPLv3 之间的区别
关于「基于另一作品的作品」的说法一直存在混淆,而这又会触发 GPL 的互惠义务。FSF 试图通过 GPLv3 讲明何时会触发互惠义务。FSF 甚至编写了一份新的 GPL 许可证(AGPL)以解决称作「ASP 漏洞」的特定混乱。
此外,FSF 试图提高 GPLv3 与其他许可证的兼容性。要将两组代码组合为更大规模的作品,两个程序就都必须允许这么做。如果两个程序的许可证授予了此类权利,那么它们将是兼容的。通过将 GPLv3 变得更具兼容性,FSF 扩展了开发选项(development options)。
第三个不同之处在于,编写 GPLv3 的目的是提高许可证在全球范围的使用率。用于描述 GPLv3 许可证权利的文字使用了多种语言,以确保国际法能理解 FSF 的意图,这与 GPLv2 以美国为中心的语言是不同的。GPLv3 还允许开发人员添加本地免责声明,这有助于增加其在美国境外的使用。
08
是否可以将 GPL 许可证与其他许可证混合使用?
人们通常以为,GPL 许可证所许可的代码不能与使用了其他开源许可证的代码混用。尽管确实存在限制,但实际上不论在 GPLv2 还是 GPLv3 下都是可能的。GPLv3 中新写入的文字更清楚地证明了这一点。FSF 明确声明 GPLv3 与 Apache 2.0 许可证相互兼容。但与原始 BSD 许可证(the original BSD license)之间存在一些问题,因为它强加了 GPL 中没有的特定要求(程序广告的要求)。
09
LGPL 涵盖了什么?
LGPL 全称 Lesser General Public License,是较为宽松的许可证(弱版权向左)。LGPL 用于许可自由软件,使其可以成为自由软件与专有软件。
LGPL 与 GPL 许可证主要有一个地方不同。对于 LGPL,关于你把源码放在自己的软件中进行扩展这方面的要求被移除。你只需要把针对原始自由库的修改提交为 LGPL 即可。由于自由库始终受到 LGPL 的约束,所以你软件的任意用户都可以修改、重新编译或替换自由 LGPL 库,并将其修改后的版本与你软件一起使用。
你还需要允许(或注意防止)对使用该库的作品进行逆向工程,以便在 LGPL 库升级后进行调试。
注意,LGPL 与 GPL 兼容,如果你愿意,你可以把 LGPL 的项目「升级」为 GPL,并将其合并至完整 GPL 许可的项目中。不过,你不能将 GPL 许可重新切换回 LGPL。
10
AGPL 涵盖了什么?
AGPL 全称 Affero General Public License,是 GPL 许可证的变体,适用于在服务器上运行的程序。如果开发人员修改了根据 GPL 发布的程序,则 GPL 希望他以相同的许可证发布修改后的程序。但如果该程序仅仅是在服务器上运行的,则开发人员实际上不会把该程序发布到世界的其他地方。
AGPL 考虑到了这一点。根据 AGPL,开发人员必须向使用该服务的所有人发布该程序的修改版本。
&
至此,我们回答了关于 GPL 许可证的十个热门问题。如果你还有其他问题,我们很乐意回答你。
本文的作者和译者均不是律师或法律工作者,因此你不应将本文视作任何形式上的法律建议。本文信息按素材原文原样奉上,未经修改。如需法律咨询,请联系你的法律顾问,或有相关从业资质或经验的律师或其他法律工作者。
原题:Top 10 GPL License Questions Answered
原文:
https://resources.whitesourcesoftware.com/blog-whitesource/top-10-gpl-license-questions-answered
作者:Rami Sass
END
开源许可证相关推荐:
1)一文读懂常用开源许可证
2)一文读懂开源许可证异同
3)一文读懂 Copyleft 开源许可证
4)十问十答 Apache 许可证
5)十问十答 CDDL 许可证