0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

如何选择开源协议?

工程师 来源:C语言中文网 作者:C语言中文网 2020-10-23 14:57 次阅读

素材来源:C语言中文网

编排:strongerHuang

有不少人认为开源就是免费,其实这个观点是错误的,今天就来谈谈关于开源的内容。

一、关于开源

开源软件在追求“自由”的同时,不能牺牲程序员的利益,否则将会影响程序员的创造激情,因此世界上现在有 60 多种被开源促进组织(Open Source Initiative)认可的开源许可协议来保证开源工作者的权益。

开源协议规定了你在使用开源软件时的权利和责任,也就是规定了你可以做什么,不可以做什么。

开源协议虽然不一定具备法律效力,但是当涉及软件版权纠纷时,开源协议也是非常重要的证据之一。

对于准备编写一款开源软件的开发人员,也非常建议先了解一下当前最热门的开源许可协议,选择一个合适的开源许可协议来最大限度保护自己的软件权益。

二、常见开源协议

1.GNU GPL(GNU General Public License,GNU通用公共许可证)

只要软件中包含了遵循 GPL 协议的产品或代码,该软件就必须也遵循 GPL 许可协议,也就是必须开源免费,不能闭源收费,因此这个协议并不适合商用软件。

遵循 GPL 协议的开源软件数量极其庞大,包括 Linux 系统在内的大多数的开源软件都是基于这个协议的。

GPL 开源协议的主要特点:

复制自由:允许把软件复制到任何人的电脑中,并且不限制复制的数量。

传播自由:允许软件以各种形式进行传播。

收费传播:允许在各种媒介上出售该软件,但必须提前让买家知道这个软件是可以免费获得的;因此,一般来讲,开源软件都是通过为用户提供有偿服务的形式来盈利的。

修改自由:允许开发人员增加或删除软件的功能,但软件修改后必须依然基于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 画了一张分析图,说明应该怎么选择开源协议,大家看了一目了然,真是清爽。

图片来自于阮一峰博客

四、开源等于免费吗?

首先,开源软件和免费软件是两个概念:

开源软件是指公开源代码的软件。 开源软件在发行的时候会附上软件的源代码,并授权允许用户更改、传播或者二次开发。

免费软件就是免费提供给用户使用的软件。 但是在免费的同时,通常也会有一些限制,比如源代码不公开,用户不能随意修改、不能二次发布等。

免费软件的例子比比皆是,QQ、微信、迅雷、酷狗、360 等都是免费软件,你可以随意使用,尽情蹂躏;但是,如果你嫌弃它们复杂,自己删除了一些无用的功能,然后在网上发布了一个精简版本供大家下载,那么你就离法院的传票不远了。

开源软件是不抵触商业的,开源的目的也不是做慈善事业,而是通过更多人的参与,减少软件的缺陷,丰富软件的功能,同时也避免了少数人在软件里留一些不正当的后门。开源软件最终还会反哺商业,让商业公司为用户提供更好的产品。

Android 就是大众最熟知的一款开源操作系统,它除了用在手机上,还用在汽车、平板电脑、电视、智能手表等其它硬件平台,小米、华为、OPPO、三星等都是 Android 的受益者,他们都赚得盆满钵满。

很多著名的开源项目背后都有商业公司支撑,它们的开发者也都有正式的工作,享受和我们一样的社会福利;如果一个成功的开源项目背后没有商业公司,这反而是不健康的,社会需要开源和商业之间的互补来促进技术的革新。

责任编辑:haq

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 编程
    +关注

    关注

    88

    文章

    3614

    浏览量

    93698
  • 开源
    +关注

    关注

    3

    文章

    3328

    浏览量

    42476
  • 源代码
    +关注

    关注

    96

    文章

    2945

    浏览量

    66734
收藏 人收藏

    评论

    相关推荐

    黄鹤开源社区正式发布

    近日,在2024开放原子开发者大会暨首届开源技术学术大会开幕式上,基于开放原子开源基金会旗下AtomGit开源协作平台搭建的黄鹤开源社区正式发布,标志着武汉市
    的头像 发表于 12-23 11:33 164次阅读

    HPLC通信设备的选择 HPLC通信协议分析

    高压液相色谱(HPLC)是一种广泛应用于化学分析和生物医学研究的技术。它依赖于精确的通信设备和协议来确保数据的准确传输和处理。 HPLC通信设备的选择 1. 数据采集卡(DAC) 功能 :用于将
    的头像 发表于 12-02 14:07 195次阅读

    重磅新品|超轻巨能飞的开源无人机套装Stamp Fly 无线摇杆Atom JoyStick

    定高和避障功能。且出厂预装调试程序,搭配AtomJoyStick作为遥控,通过ESP-NOW协议通信,用户根据需要可选择自动或手动模式,轻松实现定点飞行和翻转等功能
    的头像 发表于 08-03 08:30 505次阅读
    重磅新品|超轻巨能飞的<b class='flag-5'>开源</b>无人机套装Stamp Fly  无线摇杆Atom JoyStick

    基于MM32F5270的Ethernet实现LwIP协议栈移植

    LwIP是轻量化的TCP/IP协议,由瑞典计算机科学院(SICS)的Adam Dunkels 开发的一个小型开源的TCP/IP协议栈。LwIP具有高度可移植性、代码开源,提供了三种编程
    的头像 发表于 06-21 10:28 1179次阅读
    基于MM32F5270的Ethernet实现LwIP<b class='flag-5'>协议</b>栈移植

    西门子S7协议与TCP协议的区别

    在工业自动化领域,通信协议选择对于确保设备间的顺畅通信和数据的可靠传输至关重要。西门子S7协议和TCP协议作为两种常用的通信协议,各自具有
    的头像 发表于 06-19 15:54 3575次阅读

    三菱MC协议与Modbus协议的区别

    在工业自动化领域,通信协议选择对于系统的高效、稳定运行至关重要。三菱MC协议和Modbus协议作为两种广泛应用的通信协议,各自具有独特的特
    的头像 发表于 06-18 11:31 2234次阅读

    深开鸿与中国矿业大学签署战略合作协议,共筑开源鸿蒙生态新篇!

    近日,深开鸿与中国矿业大学签署战略合作协议,双方将围绕着软件研发创新、开源社区共建、软件人才合作三大领域深化合作,共同推动开源鸿蒙技术的发展与应用。深开鸿开源社区开发部总经理巴延兴、中
    的头像 发表于 06-18 08:33 537次阅读
    深开鸿与中国矿业大学签署战略合作<b class='flag-5'>协议</b>,共筑<b class='flag-5'>开源</b>鸿蒙生态新篇!

    求助,大家开发以太网时候使用什么协议比较多?

    也是瑞典计算机科学院(SICS)的Adam Dunkels 开发的一个小型开源的TCP/IP协议栈。 lwip提供三种API:1)RAW API 2)lwip API 3)BSD API LwIP实现
    发表于 05-16 08:01

    Redis 开源协议调整,我们怎么办?

    许可,时间点恰逢刚刚完成最新一轮融资,宣布的时机耐人寻味。 Redis 协议调整,对云计算厂商的影响 Redis 协议调整听起来可能没什么,但在开源项目领域是一个大问题。这并不是 Redis 官方第一次
    的头像 发表于 05-09 22:59 429次阅读
    Redis <b class='flag-5'>开源</b><b class='flag-5'>协议</b>调整,我们怎么办?

    迅龙软件加入开放原子开源基金会和OpenHarmony 项目,共建开源新生态

    近日,迅龙软件与“开放原子开源基金会”签署协议,加入“开放原子开源基金会”(以下简称“开源基金会”),成为开源基金会白银捐赠人,这标志着迅龙
    的头像 发表于 04-30 17:50 1036次阅读
    迅龙软件加入开放原子<b class='flag-5'>开源</b>基金会和OpenHarmony 项目,共建<b class='flag-5'>开源</b>新生态

    发布/订阅消息传递协议有哪些?为什么这类协议在物联网应用广泛

    轻量级的发布/订阅消息传递协议,适用于物联网设备之间的通信。 2、AMQP 协议:AMQP 协议是一种高级消息队列协议,也是一种发布/订阅消息传递
    的头像 发表于 04-18 15:33 545次阅读

    DDS协议测试实践及问题分析

    ,被测协议选择了一个在汽车行业内广泛使用的开源DDS产品。近年来随着开源软件社区的不断发展和成熟,越来越多的整车厂在选择DDS
    的头像 发表于 04-12 08:26 581次阅读
    DDS<b class='flag-5'>协议</b>测试实践及问题分析

    新版 Redis 不再“开源”,对使用者都有哪些影响?

    OSI(开放源代码促进会)定义下不再是严格的开源产品。该变化引发 Redis 使用者的广泛激烈讨论,那么对 Redis 使用者都有哪些影响呢? Redis 协议变更之后, 都有哪些影响? BSD 协议
    的头像 发表于 03-27 22:30 489次阅读
    新版 Redis 不再“<b class='flag-5'>开源</b>”,对使用者都有哪些影响?

    Profinet协议转换为CanOpen协议来连接CanOpen伺服驱动器的应用

    和通信协议。根据设备手册或其他相关资料,确定设备支持的通信接口和协议选择无锡耐特森Profinet转CanOpen网关。根据伺服驱动器的通信接口和协议
    的头像 发表于 01-10 10:27 419次阅读

    RocketMQ协议是什么?RocketMQ协议特点

    RocketMQ是由阿里巴巴开发的开源分布式消息和流处理平台。它提供可靠、可扩展和高性能的消息传输和实时处理解决方案。 RocketMQ使用一种名为RocketMQ协议的通信协议。该协议
    的头像 发表于 01-03 16:11 810次阅读