前言

  自理查德·斯托曼于1983年发起GNU计划时起,开源的理念逐渐在互联网传播。开源运动后来分化出了开源软件和自由软件两个说法,自由软件根据自由软件基金会的定义是指一类可以不受限制地自由使用、复制、研究、修改和分发的,尊重用户自由的软件,而开源软件是指一类源代码可以任意获取的计算机软件,这种软件的版权持有人在软件协议的规定之下保留一部分权利并允许用户学习、修改、增进提高这款软件的质量,而对它们进行约束的就是开源协议。目前互联网存在诸多开源协议,每种协议的要求各不相同,下面介绍一下几个常见的开源协议。

GPL

  GNU General Pubilc Licence(GPL)是一种广泛使用的开源软件许可证,可以保证终端用户得自由运行,学习,共享和修改软件,目前已经发布到了第三版。GPL协议最主要的几个原则:

  1. 可自由复制
    你可以将软件复制到你的电脑,你客户的电脑,或者任何地方。复制份数没有任何限制。
  2. 可自由分发
    在你的网站提供下载,拷贝到U盘送人,或者将源代码打印出来分发。
  3. 可以用来盈利
    你可以在分发软件的时候收费,但你必须在收费前向你的客户提供该软件的 GNU GPL 许可协议,以便让他们知道,他们可以从别的渠道免费得到这份软件,以及你收费的理由。
  4. 可自由修改
    可以自由添加或删除某个功能,或在别的项目中使用部分代码。唯一的要求是,使用了这段代码的项目也必须使用 GPL 协议。

简单的讲,选择GPL协议,任何衍生代码都必须开源,并且以相同的许可条款分发,这就是为什么我们能用到各式各样的免费Linux发行版的原因。

LGPL

  LGPL是GPL的一个为主要为类库使用设计的开源协议。和GPL要求任何使用/修改/衍生自GPL类库的的软件必须采用GPL协议不同。LGPL允许商业软件通过类库引用(link)方式使用LGPL类库而不需要开源商业软件的代码。这使得采用LGPL协议的开源代码可以被商业软件作为类库引用并发布和销售。

但是如果修改LGPL协议的代码或者衍生,则所有修改的代码,涉及修改部分的额外代码和衍生的代码都必须采用LGPL协议。因此LGPL协议的开源代码很适合作为第三方类库被商业软件引用,但不适合希望以LGPL协议代码为基础,通过修改和衍生的方式做二次开发的商业软件采用。

GPL/LGPL都保障原作者的知识产权,避免有人利用开源代码复制并开发类似的产品。

BSD

  BSD开源协议是一个给于使用者很大自由的协议。基本上使用者可以”为所欲为”,可以自由的使用,修改源代码,也可以将修改后的代码作为开源或者专有软件再发布。但”为所欲为”的前提当你发布使用了BSD协议的代码,或则以BSD协议代码为基础做二次开发自己的产品时,需要满足三个条件:

  1. 如果再发布的产品中包含源代码,则在源代码中必须带有原来代码中的BSD协议。
  2. 如果再发布的只是二进制类库/软件,则需要在类库/软件的文档和版权声明中包含原来代码中的BSD协议。
  3. 不可以用开源代码的作者/机构名字和原来产品的名字做市场推广。

BSD代码鼓励代码共享,但需要尊重代码作者的著作权。BSD由于允许使用者修改和重新发布代码,也允许使用或在BSD代码上开发商业软件发布和销售,因此是对商业集成很友好的协议。而很多的公司企业在选用开源产品的时候都首选BSD协议,因为可以完全控制这些第三方的代码,在必要的时候可以修改或者二次开发。

MIT

  MIT 协议可能是几大开源协议中最宽松的一个,核心条款是:
该软件及其相关文档对所有人免费,可以任意处置,包括使用,复制,修改,合并,发表,分发,再授权,或者销售。唯一的限制是,软件中必须包含上述版 权和许可提示。这意味着:

  1. 你可以自由使用,复制,修改,可以用于自己的项目。
  2. 可以免费分发或用来盈利。
  3. 唯一的限制是必须包含许可声明。

Apache

  Apache Licence是著名的非盈利开源组织Apache采用的协议。该协议和BSD类似,同样鼓励代码共享和尊重原作者的著作权,同样允许代码修改,再发布作为开源或商业软件。需要满足的条件也和BSD类似:

  1. 需要给使用代码的用户一份Apache Licence
  2. 如果你修改了代码,需要在被修改的文件中说明。
  3. 在延伸的代码中(修改和有源代码衍生的代码中)需要带有原来代码中的协议,商标,专利声明和其他原来作者规定需要包含的说明。
  4. 如果再发布的产品中包含一个Notice文件,则在Notice文件中需要带有Apache Licence。你可以在Notice中增加自己的许可,但不可以表现为对Apache Licence构成更改。
  5. Apache Licence也是对商业应用友好的许可。使用者也可以在需要的时候修改代码来满足需要并作为开源或商业产品发布/销售。

    附录

    开源协议关系图

    阮一峰老师有一张简洁明了的图来解释上述几种开源协议的关系
    还有一张来自GcsSloop dalao的图片

    五大开源协议官方网站

    BSD: https://en.wikipedia.org/wiki/BSD_licenses
    MIT: https://opensource.org/licenses/MIT
    Apache2.0: http://www.apache.org/licenses/LICENSE-2.0
    GNU GPL: https://www.gnu.org/licenses/gpl-howto.html
    LGPL: http://opensource.org/licenses/lgpl-license