开源协议是什么?有哪些?如何选择?
开源软件在追求“自由”的同时,不能牺牲程序员的利益,否则将会影响程序员的创造激情,因此世界上现在有 60 多种被开源促进组织(Open Source Initiative)认可的开源许可协议来保证开源工作者的权益。
开源协议规定了你在使用开源软件时的权利和责任,也就是规定了你可以做什么,不可以做什么。
开源协议虽然不一定具备法律效力,但是当涉及软件版权纠纷时,开源协议也是非常重要的证据之一。
对于准备编写一款开源软件的开发人员,也非常建议先了解一下当前最热门的开源许可协议,选择一个合适的开源许可协议来最大限度保护自己的软件权益。
1) GNU GPL(GNU General Public License,GNU通用公共许可证)
只要软件中包含了遵循 GPL 协议的产品或代码,该软件就必须也遵循 GPL 许可协议,也就是必须开源免费,不能闭源收费,因此这个协议并不适合商用软件。
遵循 GPL 协议的开源软件数量极其庞大,包括 Linux 系统在内的大多数的开源软件都是基于这个协议的。
特点 | 说明 |
---|---|
复制自由 | 允许把软件复制到任何人的电脑中,并且不限制复制的数量。 |
传播自由 | 允许软件以各种形式进行传播。 |
收费传播 | 允许在各种媒介上出售该软件,但必须提前让买家知道这个软件是可以免费获得的;因此,一般来讲,开源软件都是通过为用户提供有偿服务的形式来盈利的。 |
修改自由 | 允许开发人员增加或删除软件的功能,但软件修改后必须依然基于GPL许可协议授权。 |
2) BSD(Berkeley Software Distribution,伯克利软件发布版)协议
BSD 协议基本上允许用户“为所欲为”,用户可以使用、修改和重新发布遵循该许可的软件,并且可以将软件作为商业软件发布和销售,前提是需要满足下面三个条件:
- 如果再发布的软件中包含源代码,则源代码必须继续遵循 BSD 许可协议。
- 如果再发布的软件中只有二进制程序,则需要在相关文档或版权文件中声明原始代码遵循了 BSD 协议。
- 不允许用原始软件的名字、作者名字或机构名称进行市场推广。
BSD 对商业比较友好,很多公司在选用开源产品的时候都首选 BSD 协议,因为可以完全控制这些第三方的代码,甚至在必要的时候可以修改或者二次开发。
3) Apache 许可证版本(Apache License Version)协议
Apache 和 BSD 类似,都适用于商业软件。Apache 协议在为开发人员提供版权及专利许可的同时,允许用户拥有修改代码及再发布的自由。
现在热门的 Hadoop、Apache HTTP Server、MongoDB 等项目都是基于该许可协议研发的,程序开发人员在开发遵循该协议的软件时,要严格遵守下面的四个条件:
- 该软件及其衍生品必须继续使用 Apache 许可协议。
- 如果修改了程序源代码,需要在文档中进行声明。
- 若软件是基于他人的源代码编写而成的,则需要保留原始代码的协议、商标、专利声明及其他原作者声明的内容信息。
- 如果再发布的软件中有声明文件,则需在此文件中标注 Apache 许可协议及其他许可协议。
4) MIT(Massachusetts Institute of Technology)协议
目前限制最少的开源许可协议之一(比 BSD 和 Apache 的限制都少),只要程序的开发者在修改后的源代码中保留原作者的许可信息即可,因此普遍被商业软件所使用。
使用 MIT 协议的软件有 PuTTY、X Window System、Ruby on Rails、Lua 5.0 onwards、Mono 等。
5) GUN LGPL(GNU Lesser General Public License,GNU 宽通用公共许可证)
LGPL 是 GPL 的一个衍生版本,也被称为 GPL V2,该协议主要是为类库设计的开源协议。
LGPL 允许商业软件通过类库引用(link)的方式使用 LGPL 类库,而不需要开源商业软件的代码。这使得采用 LGPL 协议的开源代码可以被商业软件作为类库引用并发布和销售。
但是如果修改 LGPL 协议的代码或者衍生品,则所有修改的代码,涉及修改部分的额外代码和衍生的代码都必须采用 LGPL 协议。因此LGPL协议的开源代码很适合作为第三方类库被商业软件引用,但不适合希望以 LGPL 协议代码为基础,通过修改和衍生的方式做二次开发的商业软件采用。
如何选择开源协议
世界上的开源协议有上百种(有兴趣的读者请猛击这里了解),很少有人能彻底搞清它们之间的区别,即使在最流行的六种开源协议——GPL、BSD、MIT、Mozilla、Apache 和 LGPL——之中做选择,也很复杂。
乌克兰程序员 Paul Bagwell 画了一张分析图,说明应该怎么选择开源协议,大家看了一目了然,真是清爽。
图片来自于阮一峰博客:如何选择开源协议
详细阅读:开源等于免费吗
开源协议是什么?有哪些?如何选择?相关推荐
- 如何为你的代码选择一个开源协议
相信很多刚踏入软件这个行业的小伙伴一如当初的我,对开源软件的各种协议不甚了解被搞昏了头脑.毕竟对于一个新生程序员来说,如何写好代码才是亟待解决的问题,无暇了解这些.随着你项目做得多了代码写得多了,你会 ...
- 【全】可供选择的软件开源协议的罗列
Public License List 罗列各种开源代码的公共协议以供选择.具体每一个协议的含义可以另外找教程文章或看官网原文,这里解决"都有什么"的问题. List of lic ...
- 开源协议有哪些?如何选择开源协议?
开源软件在追求"自由"的同时,不能牺牲程序员的利益,否则将会影响程序员的创造激情,因此世界上现在有 60 多种被开源促进组织(Open Source Initiative)认可的开 ...
- VNPY官方开源项目为什么不能选择MIT开源协议
其他文章 <VNPY项目开源地址> https://gitcode.net/vnpy/vnpy <vnpy3.0新版策略自动生成回测文件功能代码解析> 众所周知,VNPY是采用 ...
- GPL、MIT、Apache...开发者如何选择开源协议?一文讲清根本区别
个人开发者到底选择GPL协议还是MIT协议? 为什么小米可以避开开源协议? 安卓是开源的,为什么华为还要自己造鸿蒙? 你知道史上最奇葩的开源协议吗? 这些问题,都将在这篇文章中找到答案. 目录 GPL ...
- GPL、MIT、Apache...开发者如何选择开源协议?一文讲清根本区别!
个人开发者到底选择GPL协议还是MIT协议? 为什么小米可以避开开源协议? 安卓是开源的,为什么华为还要自己造鸿蒙? 你知道史上最奇葩的开源协议吗? 这些问题,都将在这篇文章中找到答案. 开源,是很多 ...
- 码云小课题 | 主流开源协议有哪些?我们该如何选择?
License是软件的授权许可,里面详尽表述了你获得代码后拥有的权利,可以对别人的作品进行何种操作,何种操作又是被禁止的.软件协议可分为开源和商业两类,对于商业协议,或者叫法律声明.许可协议,每个软件 ...
- 开源协议(GPL,LGPL,BSD,MIT,Apache)的说明和选择
1,摘要 本文介绍五种开源协议GPL,LGPL,BSD,MIT,Apache,以及如何选择这几种协议. 2,开源协议的选择逻辑图 如何为代码选择开源许可证,这是一个问题. 世界上的开源许可证,大概有上 ...
- 常用开源协议介绍以及开源软件规范列表
1. 开源协议介绍 GPL: General Public License,开源项目最常用的许可证,衍生代码的分发需开源并且也要遵守此协议.该协议也有很多变种,不同变种要求会略微不同. MPL: MP ...
最新文章
- python绘制动点_Python asyncore / asynchat 基本传输实验 - Jacky Liu's Blog
- c语言c2182是什么错误,C语言中一种更优雅的异常处理机制
- Tomcat 8熵池阻塞变慢详解
- 使用 class-dump 扫描 app 关键字
- DCMTK:使用dcmimage 库将DICOM图像转换为PPM或PGM
- 三星全速进军物联网 所有产品都将内置互联功能
- 对List.Sort的简单研究
- Oracle 11g ora 15018,OracleASM错误之--ORA-15031、ORA-15014
- C语言printf语法
- 使用 Spring 2.5 基于注解驱动的 Spring MVC
- 使用Windows自带的录音机进行wav转mp3的操作
- P3C-PMD自定义规则实战
- 计算机绘出一条虚线算法步骤,计算机图形学 第二章 基本图形生成算法.ppt
- Linux系统GPU压力测试
- java压缩JPG 、PNG图片
- 截取文件名后缀和总页数计算
- 打造成功IT项目经理——光环国际——读感
- php如何把线条变粗,科学网—AutoCAD线条加粗秘诀(转载收藏) - 顿玉环的博文...
- “智多星”智能手机销售网
- 同个网络计算机之间怎么共享,在局域网环境下的多台电脑之间如何实现文件共享需求呢?...