“开源”并非“自由软件”

将“开源”与“自由软件”混淆会削弱自由软件的意义。
842 位读者喜欢这篇文章。
Open organization buildings

Opensource.com

在开源领域,使用诸如FLOSS(自由/开放源码软件)之类的术语很常见,这随意地将开源自由软件这两个术语混淆在一起,而这两个术语经常被互换使用。如果我不承认自己也曾犯过同样的错误,那将是我的疏忽。我以后不会再这样做了——或者至少我会尽量避免——原因很简单:互换使用这两个术语对自由软件和开放媒体倡导者(即“反 DRM”)的目标是有害的。继续这种做法会削弱自由软件及其相关运动的基本信念。

自由软件关乎自由

自由软件是一场社会运动,几乎没有商业利益的影子——它存在于宗教和哲学的领域。自由软件是一种生活方式,具有强烈的道德准则。自由软件精神的核心思想是,每个人都应该能够使用、修改和分享,但有一个明确的限制,即你不能在不分享的情况下进行修改。这就是“自由软件是一种病毒”迷因的由来,这让GNU GPL 对于某些商业人士来说显得格外可怕。拥抱自由软件也意味着拥抱共享文化和强制共享,这对大多数企业来说都太过分了。自由软件的目的是颠覆现有专有 Unix 供应商的秩序,并强制执行共享原则。当谈到拥护这种自由时,很难在不承认正在进行的为解锁设备、开放媒体格式、网络中立性和免受私人以及政府监视而进行的斗争的情况下,拥抱自由软件文化和哲学。在本文的其余部分,我将使用“自由软件”作为所有这些运动的简称。

开源则完全是另一回事:供应链效率

十年前,当我写下没有开源社区时,我提出了一个问题:“开发者为什么要发布开源代码?” 事实证明,从运营的角度来看,这样做是有充分理由的。

拥抱开源就是拥抱一种利用去中心化供应链的开发模式。在过去,专有供应商会内部控制整个软件供应链,而开源模式直接反驳了这种方法。开源模式是关于使用来自多个来源的通用组件,以在创建基于软件的产品和服务时实现更高的效率和敏捷性。

最初,开源项目确实大量使用了 GPL 许可的软件,这是因为 GNU 项目的启动时间比第一个 Linux 内核早了大约 10 年,并且至少比开源这个术语的出现早了 15 年。这种先发优势的效果是,当开源作为一种商业友好的概念开始流行时,已经存在大量的 GPL 许可代码——更不用说成熟的共享文化了。

现在,新的开源项目出现了一种趋势,即从 copyleft GPL 风格的许可转向“宽松”的 Apache 风格的许可,这应该不足为奇。事后看来,这是不可避免的。在一个由商业利益而非哲学定义的世界上,强制共享实际上并没有意义。当然,有人可能会争辩说它确实有意义。毕竟,许多公司围绕 GPL 许可的 GNU 和 Linux 代码形成了有利可图的生态系统。但让我们假设大多数商业人士不同意强制共享这一点。

在 Apache 风格的开源模式中,开发者可以选择是否发布他们的修改。他们通常会这样做,仅仅是因为他们已经意识到了参与开源生态系统的好处——但也有很多人有时不会这样做。在一个开源的世界里,这根本无关紧要。如果开源开发的目的是优化你的供应链和规模经济,谁会在乎共享呢?

开源的胜利

重要的是要记住,在大教堂与集市中,埃里克·S·雷蒙德专门指出开源模式更优越,这是伟大文化分歧的开始:开源完全是为了更好的软件,“只要有足够的眼睛,所有 bug 都是浅显的”;而自由软件则是关于通过共享实现的开明存在。开源是一种更优越的模式的观点最终被证明基本上是正确的,因为开源已成为技术创新的首选模式。如果使用得当,开源流程可以为供应商提供竞争优势,而开源原则可以让项目更高效地运行。

具有讽刺意味的是,正是这种令人印象深刻的开源胜利——或者至少是我们对它的解读——对自由软件构成了真正的威胁。当这些术语被互换使用时,就没有细微差别或差异化的空间。因此,开源的胜利变成了自由软件的胜利,丝毫没有质疑这是否真的是事实。

但自由软件真的赢了吗? 让我们考虑另一种观点,即自由软件的胜利看起来与开源非常不同。如果开源的胜利看起来像是开源生态系统中更高的效率和更多的创新,那么自由软件的胜利看起来像什么呢?

如果自由软件“获胜”

如果我们从自由软件是关于共享哲学和围绕它建立的道德准则这一前提开始,那么如果自由软件的哲学与开源原则一样成功,那意味着什么呢? 如果我是正确的,它们是不同的,那么这种哲学和道德准则的成功肯定会以不同于我们现在看到的方式体现出来。

在一个自由软件获胜的世界里,锁定式的云架构会占主导地位吗? 大多数手持设备会是专有的且难以更改吗? 在任何平台上使用任何服务都会很困难吗? 我们会如此轻易地将我们的隐私交给媒体公司吗? 那么,在一个开源超级成功的世界里,为什么以上所有情况都是真的呢? 如果我们宣布开源已经获胜——我相信这样做是安全的——我们怎么可能宣布自由软件也获胜了呢? 这就是术语混淆具有积极危害性的地方。 通过互换使用它们,你正在让各地希望确保云端共享、网络自由、平等技术访问权和改善所有人隐私的自由软件倡导者泄气。

当自由软件倡导者发声时,许多开源支持者宁愿他们闭嘴走开。 几个月前,我曾在一次谈话中提到我们需要教育人们了解开源原则。 我的错误。 看看将这两件事混淆会给我们带来什么? 一位技术主管回应说:“我们真的还需要那样做吗?” 一些开源支持者认为,由于开源已经获胜,“自由市场”将解决问题,我们不必担心这些哲学问题。 因此,没有必要就标准、隐私和自由软件游说政府,因为,嘿,市场这只看不见的手正在引导我们朝着正确的方向前进。 随着开源因市场趋势而取得成功,对于推动技术文化向前发展,存在着太多的掉以轻心。

另外,我忍不住指出,这种类型的神奇思维与弗朗西斯·福山在 1989 年从历史的终结与最后之人中提出的理论惊人地相似,即世界各地的社会和民族国家正在不可避免地走向更多的自由和民主。 对于世界三分之二的人口来说,情况如何呢?

自由软件本身很重要

我们冒着将整整一代人输给租赁文化的风险,实际上没有拥有任何数字产品或控制我们可以与我们的媒体和设备互动的方式。 通过不拥抱自由软件的理想,我们冒着破坏自由软件倡导者所做的必要工作的风险。 自由软件的理想需要一种修改和共享文化来约束我们的企业霸主,这是我们在现代云、网络和物联网平台上正在迅速失去的东西。 如果我们能够强制执行自由软件原则,坦率地说,世界将会变得更美好。 我不必仅仅为了访问我付费的技术服务而使用特定的平台。 世界各地的贫困学生不会面临更多的教育机会障碍。 代表性不足的社区将拥有更多权力来控制自己的命运并创建成功的社区,他们可以利用这些社区作为对抗其他宁愿维持现状的世界的制衡力量。

我们都应该努力确保我们拥有我们设备上的技术,我们拥有我们的信息,并且我们可以捍卫我们的隐私。 谁拥有管理我们生活的信息,谁就拥有通往我们思想的途径和未来垄断的机制,这确实具有真正的经济影响。

好吧,我想我最终还是无法摆脱经济论点:忽视自由软件的哲学和理想,就会面临可怕的未来,即对言论、思想以及商业自由的限制。

标签
JM head shot
John Mark Walker 是 Fannie Mae 的开源项目办公室主管,也是一位长期的开源社区、产品和战略专家。 他创立了开源企业网络 (OSEN),并且是 Glyptodon, Inc. 的顾问。

39 条评论

开源在“自由软件”失败的地方取得了成功。 开源和“自由软件”之间的区别实际上是自由意志主义和共产主义之间的区别。 对于开源来说,自由是一种手段,目的是建立一个充满活力的生态系统,让每个人共同努力构建伟大的软件基础设施。 对于自由软件人士来说,自由本身就是目的。 理查德·斯托曼是一个人们竭力避免的左翼怪人,这并没有任何帮助。

你关于自由意志主义与共产主义的评论完全偏离了主题。 自由意志主义从不认为自由是一种达到目的的手段。 自由意志主义关注自由作为一种道德价值本身,这就是为什么自由软件运动的许多积极支持者都是自由意志主义者。 当然,RMS 不是自由意志主义者,所以显然自由软件运动比仅仅是自由意志主义者更大。 但断言自由软件是共产主义简直是无稽之谈,即使有共产主义者支持自由软件。 自由软件实际上得到了广泛政治意识形态的支持。

回复 作者:IGnatius T Foobar (未验证)

这与我的看法也一致。 我对自由意志主义的不满在于,它将自由的字面意义置于其精神之上,因此,即使市场限制和国家资助的社会计划被证明更有效并且最终提供了更大的利益,它似乎也对市场限制和国家资助的社会计划采取了道义上的厌恶。

无论如何,我以与本文作者相同的视角看待开源。 也许这是一个混合体,其中一些人是善意的,另一些人是为了炒作和商业,但他们根本不在乎其他任何事情。 然而,开源的净平衡是一艘漫无目的漂流的船,没有真正的承诺,并且与自由意志主义运动没有任何相似之处。

回复 作者:wolftune

Eleanor,我喜欢你表达对自由意志主义不满的方式。 这完全符合我的感受,我要借鉴一下。

回复 作者:Eleanor Suarez (未验证)

“对于开源来说,自由是一种手段,目的是建立一个充满活力的生态系统,让每个人共同努力构建伟大的软件基础设施。”

这个论点的问题在于:本文中使用的“开源”可以用来阻止一个充满活力的生态系统,因为改进不必共享。 宽松许可之所以受欢迎,部分原因是它们允许公司利用他人的工作在其之上构建封闭的生态系统。

回复 作者:IGnatius T Foobar (未验证)

“自由”软件是谎言。 这是一个被恶霸用来恐吓他人,强迫他人接受他们不切实际和反社会信仰的营销标签。 它与自由无关。

我不同意。 自由软件是为了确保授予下游下一个人的自由权能够一直传递下去。 自由软件许可实际上与宽松许可相同,只是有一点不同:你没有剥夺他人自由的自由。

回复 作者:Sarah Ryzecka (未验证)

Aaron,我尊重你的意见,但请你找到一种更文明的方式来表达它。 没有必要对抗和攻击他人。

回复 作者:wolftune

谢谢,VM。 我完全同意。 我没有攻击任何人,但我确实是对抗性的。 OP 评论一开始就说“自由软件是谎言”,而我(虽然很累,但仍然知道文本无法清晰地传达意思)旨在直接指出 OP 是多么的无建设性和对抗性。 但我很高兴看到你对我的回复,它很到位。

回复 作者:vmbrasseur

感谢您花时间了解开源和自由软件之间的区别,特别是以一种形式分享文本,如果人们花时间阅读它,可以更好地熟悉它。

友情提醒,我们喜欢 Opensource.com 上的热烈讨论/辩论,只要它们保持尊重并且不违反我们的使用条款/社区行为准则:https://open-source.net.cn/legal

“自由软件精神的核心思想是,每个人都应该能够使用、修改和分享,但有一个明确的限制,即你不能在不分享的情况下进行修改。”

这是真的吗? 我的理解是,我可以随意修改自由软件供个人使用,而没有任何强制要求分享这些修改。 但是,如果我选择分享软件的修改版本,我必须反过来分享修改后的源代码。 是这样吗?

哦,对了 - 应该说,你不能在不以源代码形式分享你的更改的情况下修改和再分发。 至少在 GPL v2 和 v3 定义的“分发”或“传递”软件的范围内是这样。

回复 作者:bbehrens

谢谢。 这很有帮助。 我怀疑这在一定程度上缓和了自由软件“强制共享”的观念,因为这是一个没有这种强制要求的特定情况。 这可能是一个有趣的支点,人们在为企业中的自由软件辩护时可以依靠它。

回复 作者:johnmark

实际上,自由软件作为一个概念甚至不推崇 copyleft,即每次您再分发时许可证强制要求的共享。 那是一种*策略*。 自由软件认为,任何人都不应因他人控制软件而限制他们对软件的使用。

所以,是的,你应该能够修改,并且没有要求分享你的修改(那将是非自由的要求)。 但是,像 BSD-3 这样的宽松的即退让的许可证本身也被完全尊重为自由软件。 *如果*每个人在发布衍生作品时都保留该许可证,那么自由软件运动中的任何人都不会对此感到不满。 问题仅在于衍生作品以专有条款发布时。 这违背了自由软件。 因此,自由软件并不是说当您与他人共享软件时,您“必须反过来分享修改后的源代码”,就许可证是否要求您这样做而言。 相反,自由软件只是说,*如果*您拥有一个法律许可证,*不*具有该要求,那么使用您的合法权力跳过共享源代码是不道德的。

简而言之:自由软件认为 copyleft 和宽松许可都很好,但宽松许可赋予您 *合法* 权力去做一些不道德的事情,而您永远不应该这样做。 因此,他们推广在法律上阻止不道德行为的许可证是可以理解的。 但是,如果行为在法律上被允许但从未发生,那也没关系。

回复 作者:bbehrens

你是对的。 只有在作品或衍生作品“传递”给其他人(使用 GPL 语言)时,GPL 才强制共享。 个人使用和个人修改是完全允许的,没有人可以强迫您发布甚至没有发布的更改的源代码。 AGPL 通过考虑通过网络服务使用等同于发布/分发目标代码而更进一步。

总而言之,GPL 许可证家族背后的目的不是最大化源代码公开,而是为了确保,在可能的范围内,程序及其所有衍生作品的所有用户都获得整套权限。

作为对开源持不可知论立场的自由软件支持者,我同意文章的其余部分所说的。 这种区分很重要。

回复 作者:bbehrens

我不得不恭敬地不同意这篇文章的前提。 我们将自由软件和开源混在一起使用 FOSS 或 FLOSS 等术语的原因是(我相信)我们大多数人认为开源与自由软件一样关乎自由。

供应链效率只是让人们接受这个概念的幌子。 这是一种营销策略。 一旦被吸引,人们就会明白这实际上是关于自由的。 我实际上认为开源没有任何效率可言。

我并没有通过使用开源来省钱。 当然,大多数开源都是免费的,但它也会产生支持成本(无论是内部的,还是外部供应商(如红帽)提供的支持)。

开源的供应效率并不高。 我仍然必须等待生产者发布新版本。

它并没有给我带来免费劳动力。 当我以开源形式发布自己的产品时,我不会自动获得人们免费为它工作。 当我确实获得免费劳动力时,我也必须通过支持这些人来为此付出代价,用他们需要的功能来回报他们,以便他们可以做出贡献等等。

不,我真正从开源中获得的是我从自由软件中获得的相同的东西:独立性!

如果项目的所有者停止支持它,我可以聘请其他人来接管,或者自己做。

如果存在安全问题,而生产者修复速度太慢,我可以自己修复。

这些事情并没有让我的业务更高效,但它们确实让它更独立。 这完全是关于自由,而不是效率。

问候,eMBee。

我应该补充一点,安卓在手机上的统治地位并不是开源的胜利。 所有安卓开发都在谷歌内部进行。 手机生产商使用安卓是因为它是免费的,但他们中的大多数人并没有从大多数代码附带的开源许可证中受益,因为谷歌实际上不允许手机制造商进行任意更改。

包含 Google Play 和其他 Google 应用的安卓(这也是大多数手机制造商分发的版本)既不是自由软件,也不是开源软件! 开源许可证的唯一受益者是谷歌自己。

请告诉我,这怎么算是开源的胜利?

开源和自由软件都没有获胜。 我们还有很长的路要走。

问候,eMBee。

回复 作者:eMBee (未验证)

完全正确!

我同意独立性是开源(以及在某种程度上,自由软件)获得关注的主要原因。

我确实觉得具有讽刺意味的是,在某些方面,自由软件搭上了开源的知名度/成功的顺风车。

我个人可以接受 John Mark(和其他人)关于我们区分这两个运动的要求。 然而,我更感兴趣的是这两个概念共享的共享/社区建设的共同方面。 开源已经证明,对于许多许多情况来说,这是一种更有效率和效果的软件构建方式。

John Mark 经常指责我是“开源实用主义者”,我欣然接受这个头衔,因为我认为*绝大多数*工作都是在更靠近自由软件<->专有软件频谱中心的空间中完成的。 我认为开源更接近该频谱的中心。

回复 作者:eMBee (未验证)

我并不认为这具有讽刺意味。 这个术语最初是由自由软件倡导者创造的,他们希望找到一种更好的方式来推广自由软件。

我确实记得至少布鲁斯·佩伦斯几年后说过:“现在是再次谈论自由软件的时候了”,这在一定程度上表明,即使他帮助创造了“开源”这个术语,他也一直是一位自由软件倡导者,并且他也期望自由软件会从“开源”这个术语中受益,但意识到这种情况并没有达到他希望的程度。

问候,eMBee。

回复 作者:guyma

我个人很喜欢这篇文章,我一直在想什么时候有人会在(有点讽刺的是)opensource.com 上解决这个问题
但是,如果要我们将自由软件与强 copyleft 许可证(GPL 等)联系起来,并将开源(自由软件的子集)与宽松许可证(Apache、BSD、MIT 等)联系起来,那么我认为这两个方面*确实*都促进了自由。 然而,它们关注的是两个不同群体的人的自由:前者是用户,后者是开发者。 强制共享更改旨在保证用户永远不会遭受供应商锁定,而例如 BSD... 嗯... 看看苹果的 OSX 就知道了,呵呵。

“前者是用户,后者是开发者”——嗯,不完全是这样。 这取决于哪些开发者。 如果开发者 A 利用宽松许可证的自由来关闭代码,那么开发者 B 就会失去宽松许可证的自由和(更新版本的)代码本身的访问权限。

回复 作者:PsynoKhi0 (未验证)

似乎文章和评论中有很多文字和努力来贬低自由软件的概念。 如果有人想免费提供他们的软件,那是他们的选择。
“开源”这个术语已经变得有点像魔术词,就像食物中的“全天然”一样。 但并非所有开源都是相同的。 在许多情况下,专有公司会发布某个项目的某些片段作为开源,以获得知名度,或许还能获得免费贡献,但这只是仍然封闭的更大的东西的片段。

我也为弗朗西斯·福山感到遗憾,他现在似乎到处都受到辱骂。 当你被一个写开源的人殴打时,那一定很可怕。

回复 作者:Greg P

实际上,虽然自从 OSI 放弃该商标以来,它不再具有法律效力,但“开源”有一个非常明确的定义,不像“全天然”。

此外,“免费”在这里是不相关的,因为“自由”的意思是“自由”,而不是价格。

您说得对,关于部分开放某些软件,但这也可以被视为部分释放某些软件。 虽然这违背了软件自由的道德规范,但被释放的部分仍然是合法的自由软件。

回复 作者:Greg P

毫无疑问,但这与其他人参与的 FLOSS 世界无关紧要,在那个世界中,自由软件的创始人和主要组织对自由软件的定义与您的定义截然不同。

回复 作者:Greg P

对不起,Greg,你的“免费如啤酒”的说法引起了我的注意。 特别是因为有一个开源许可证,许可人以半开玩笑的方式要求,如果他的软件的任何用户在酒吧遇到他,那么他们可以请他喝酒。

基本上,啤酒并不免费,除非你最近抢劫了一家酒店,或者你有很棒的家酿啤酒[而且那可能也不是免费制作的]! :-)

回复 作者:Greg P

当有人试图将“自由软件”和“开源”分开时,我总是不得不抱怨。

如果我们将“开源软件”定义为满足开源定义 (OSD) 的任何软件,并将“自由软件”定义为满足四项自由要求的任何软件,那么很容易将 OSD 的 10 项要求映射到自由软件的四项要求。

我在 2009 年就做过:https://www.adventuresinoss.com/2009/05/07/fauxpen-source/

因此,根据定义,开源软件就是自由软件,反之亦然。

自由软件定义的问题在于那些讨厌的词语“这样你就可以帮助你的邻居”。 听起来像共产主义,对吧? 那些自由软件的书呆子一定只是一群反商业的嬉皮士。

但是……当我看到有人试图在两者之间划清界限时,这通常是“伪开源”的先兆。首先,他们试图将自由方面从开源中分离出来,然后当他们试图从 OSD 中剥夺一两个自由(例如创建和分发衍生作品的权利)时,他们会躲在“好吧,你仍然可以看到源代码,所以它一定是‘开源’的,对吧?这不是‘自由’软件。”

错误。

我的默认说法是“开源”(见鬼,我正在 opensource.com 上发布这篇文章),我的意思是软件只是因为满足了 OSD 的要求而变得更好。但当关注事物的自由方面时,我也会说“自由和开源软件”或“自由软件”。

我不是说约翰·马克是故意试图区分两者,他在文章中提出了一些很好的观点,但我们应该始终清楚,两者之间没有实际的区别——更多的是意图问题。

谢谢!我很高兴有人也提出了这个非常明显的观点。我至少已经思考这个问题十几年了。我们能不能停止争论,一起走向统治世界? ;-)

回复 ,作者是 Sortova

如果开源获胜了……那么所有 OSBNFS(开源但非自由软件)项目和/或产品在哪里?

您不必看得太远:您自己的手机很可能就是开源但不是自由软件。

的确,谷歌的所有服务都建立在开源的基础上,但是您能控制您的数据以及它们如何被处理吗?谷歌可能会发布大量代码和研究论文,但您的私人信息是他们的。AGPL?想都别想。

糟糕的物联网之所以如此糟糕的原因之一正是因为开源。过去我们嘲笑 Windows 的安全性很差,而当出现运行 Linux 的新设备时,我们很高兴。至少 Windows 还有 SP2。现在我们被永远存在的漏洞包围,不断受到攻击。即使几乎每个组件都是使用开源软件构建的,从引导加载程序到应用程序堆栈,我们也有固件锁和粗心大意,这使得这种开放性毫无意义。

如今,几乎每台设备和几乎每项在线服务都至少有一个开源组件。即使是 Windows 也是部分开源的,因为微软现在已经开源了如此多的组件。而且几乎在任何地方,用户都没有真正获得 4 项基本自由,尤其是自由 1 的一部分:自由地更改程序以使其执行您希望的操作。

回复 ,作者是 Miguel A.(未验证)

主要问题是许多人认为所有自由软件都是在 Copyleft 许可(如 GPL)下分发的,但事实并非如此。有根据非 Copyleft 许可发布的自由软件,因此如果您不想,您不必在相同的许可下发布该软件的修改版本;如果您希望您的版本保持自由软件,您只需遵守自由 0、1、2 和 3,无论您选择什么自由软件许可;仅此而已。

我不得不说,从我的角度来看,我完全同意开源不是自由软件,并且我强烈偏好宽松许可软件中缺乏对自由/Copyleft 的任何强制执行。我试图明确指出,开源、宽松许可的软件不会询问您的作品是否是衍生的、传播的或分发的,您可以随心所欲地做,对于这些条件中的任何一个是否是自由的,几乎没有歧义。我不明白自由的 Copyleft 许可如何降低租赁文化的风险——大量的 Copyleft 软件为云提供动力,但数据通常仍然是封闭的/由一个小团体拥有。

我认为生态系统比自由软件更大,我们欠自由软件运动很多,那也是我开始的地方。然而,我做出了一个非常自觉的选择,就像我认为其他人一样,转向为我的工作使用更简单、更宽松的开源许可证。我个人想要一个更开放的世界,但我没有时间进行法律辩论、许可证兼容性和 Copyleft 许可的细微差别。

让我们看看关于开源是关于供应链效率的前提。用一句英国谚语来说,我不得不说那是胡说八道!

我在思科系统公司的供应链部门工作了 10 年,我的职责是管理从工程部门(商业和开源)进入供应链的所有软件,并确保许可得到遵守。

在这个辩论中容易被忽视的几个问题对于像思科这样的大公司来说是存在问题的,这些公司已经投入数百万美元来构建全面的合规流程。这个流程是跨公司的,包括数百人,开发人员、业务经理、律师、供应链专业人员和经理等等。为什么?嗯,有一个相当公开的原因,是在收购 Linksys 之后出现的。那么问题是什么呢?

“自由和开源”这个短语的认知和引起的困惑。我们将重点缩小到开源,并培训了所有开源在知识产权上都归他人所有,并通过一种或许可证工具使其代码可供使用而无需初始成本(金钱成本)的原则。

但是,在大多数情况下,使用该软件是有成本的。正如之前已经提到的,分发通常是某些类型的开源,特别是 Copyleft(如 GPL)的重要触发因素。此外,您还必须小心(即使使用 BSD 和其他更宽松的许可证),您要遵守适用许可证中的义务,对于一般的非 Copyleft 许可证,这要求您公开作者署名。

如果您使用 GPL,您必须提供访问权限,无论是作为您分发的一部分,还是通过随附您作品的某些出版物中的要约,访问 GPL 源代码以及您对该代码所做的任何和所有更改。此外,如果您在开发产品以及将您的 IP 与所述 GPL 或 Copyleft 代码结合使用时不够聪明,那么也需要发布这些内容。那么猜猜怎么着?您的工程部门现在必须在其同行评审、静态分析或其他开发流程中加入额外的步骤,以检查这些事项并证明他们已经这样做了。大多数繁忙的工程部门讨厌有东西妨碍他们,拖慢他们的速度。

许多 GPL 代码和其他开源代码因混合许可而臭名昭著。这对于商业许可证来说不是问题,因为您可以追究供应商对下游许可的责任。但对于开源,你不能!这意味着根据 MIT 许可(例如)许可的代码可能包含来自 BSD 或 Apache 风格许可证的代码。猜猜怎么着——然后您有义务遵守构成名义上 MIT 许可证的每个许可证中规定的要求,但实际上并非如此。

在许多情况下,商业供应商可以将开源分发到供应链中,Red Hat 和 Google 立即浮现在脑海,但如今所有商业供应商都以某种方式使用开源。许多人认为商业供应商的许可协议涵盖开源使用。但事实并非如此 :-)。如果您收到代码,您有义务遵守许可证。所以您最好知道他们给了您什么。

关于“诱饵和转换”许可。那是一种声称是开源的许可证,但随后以某种方式将您引入某种形式的商业关系。这些是真实存在的,并且可能代价高昂。有时,“所谓的”开源许可证,例如 Sun Microsystems 当年首创的著名的社区源代码许可证,允许出于有限目的的免费和开放使用,并且像 GPL 许可证一样,包含一个要求商业许可证的分发条款。值得庆幸的是,这些许可证越来越少,但它们仍然存在。最流行的是类似于 Android 的许可证,您获得一些基本的开源功能,但要获得更好的性能或更高的加密或其他“高级”功能,您需要付费。

通常,其中一些许可证被放置在网站上的简单点击浏览中,大多数人懒得阅读,但会点击它们,以便获得他们的软件补丁!

最后(但这并非详尽列表),使用开源的真正成本是所需的额外维护。一些开源社区在更新、错误修复和安全补丁等方面非常有效率,但有些则不然。当您开始使用开源时,您最好在您的工程部门建立一个合适的支持团队并加入社区,这样您就可以最大限度地提高代码保持工作状态的机会。您的另一个选择是去找财务部门要一些钱,支付给像 Red Hat 这样的公司来为您做这件事。

所以,让我最后说一句,没有“免费”的开源。有“自由使用”的开源,您不会寻求从其使用中获利。就像生活中的任何事情一样,没有免费的午餐。

当您决定分享您用开源所做的工作并让其他人使用您的工作时,您就将供应链延长了一个环节。您现在有义务向您的客户(无论是商业实体还是朋友)提供受支持且合规的产品,并让他们了解他们的义务。您还有义务向您的供应链这样做,并遵守您在最初采用和使用代码时同意的条款。您这样做是理所当然的,毕竟,您使用的东西不是从树上长出来的。

小心点!

嗨。

这是我读过的关于开源/自由软件的最糟糕的文章。

根据定义,任何自由软件都必须是开源的。但是,例如,任何需要任何私有软件才能运行的项目都不能是自由软件,即使您可能认为它是开源的。

您可能认为我错了,但您可以阅读这个:https://open-source.org.cn/docs/osd

您可以清楚地理解,这与自由软件的四项规则相同。自由再分发,自由修改,自由再分发。自由软件处理软件的所有权,开源处理源代码的可用性,以便作为开发方法进行阅读或修改。

在我看来,自由软件是一个通常用于宣传目的的术语,由 FSF 推广。通常是这样,因为“自由”这个词通常会引起潜在技术用户的注意。宣传策略中固有一些开源的方面,因为有一些软件工具既符合自由软件又符合开源软件的条件。例如——LibreOffice。这通常会导致使用 FOSS 和 FLOSS。必须注意的是,在自由软件的情况下,访问源代码并不保证——例如 Skype 客户端。

另一方面,开源确实提供了对源代码的访问,无论是受限制的,仅限 группеople 查看,还是对公众开放。开源的重点通常是为理解源代码的人提供访问权限,以便维护或改进功能。这是 OSI 通常提倡的立场。

就业务而言,在开源或闭源中开发任何解决方案所需的工作量是相同的。然而,企业转向更多地从开源使用中获益。开源软件是可扩展且易于维护的。

Creative Commons License本作品根据知识共享署名-相同方式共享 4.0 国际许可协议获得许可。
© . All rights reserved.