写点什么

采用开源工具:善意推定,但也要做好沟通

作者:Ben Linders

  • 2024-01-17
    北京
  • 本文字数:1485 字

    阅读完需:约 5 分钟

采用开源工具:善意推定,但也要做好沟通

按照 Hila Fish 的说法,开源项目的好处是支持快速创新,让我们可以灵活地定制和调整工具,而且代码是透明的,有利于增强安全性。其缺点是通过隐匿实现安全的策略就行不通了,开源很容易被滥用,并且当开源工具没有公司支持时,可能会导致可维护性降低。


在 DEV: Challenge Accepted 2023 大会上,Hila Fish 谈了从 DevOps 视角看开源项目。


Fish 说,由于开源项目的开放性,它们的创新速度往往比较快。DevOps 团队可以利用这个快速的创新周期,采用新技术和实践来改进他们的流程。Fish 提到了持续集成、持续交付(CI/CD)、容器化和基础设施即代码(IaC)等领域。在这些领域,开源工具和解决方案推动了 DevOps 的创新。


DevOps 的核心原则之一是能够根据组织的独特需求来定制流程和工具,Fish 解释道:


开源软件提供了定制和调整工具以适应特定工作流和需求所需的灵活性。她补充说,DevOps 团队可以修改、扩展和集成开源解决方案,从而创建一个最优的工具链。


开源项目强调透明,允许任何人审查源代码。Fish 说,这可以加强软件开发周期内的安全工作,因为团队有机会检查代码中的漏洞并进行必要的改进。开源项目的协作特性通常可以使其对安全性和其他各种问题做出快速响应,从而帮助 DevOps 团队保证环境的安全和稳定。


开源项目也有一些缺点。Fish 提到,“通过隐匿实现安全”的概念并不适用于开源工具。Fish 说,专有软件公司可以声称他们的代码比开源软件更安全,因为代码不公开,黑客很难利用其漏洞。


Fish 还提到,开源软件很容易被滥用:


最近有一些案例,比如“Colors”NPM 包和“FakerJS”被维护者破坏 / 删除,每个人都有自己的原因。我们要知道,当我们在自己的环境引入开源工具时,这种情况是有可能发生的(即使不是经常发生)。


Fish 说,很多开源工具并没有得到公司的支持。由于维护者是个人,所以他们可以决定停止维护这些项目:


如果我们集成这类项目,这意味着我们要么自己维护它,要么迁移到另一个维护良好的工具。


Fish 提到,对于开源,你需要“善意推定(assume good faith)”。如果你在生产环境中使用一个开源工具,它有一个 Bug,而你打开了一个问题来修复它,那么这个 Bug 的修复可能需要几个月甚至更长的时间,因为他们不欠我们任何东西。


是的,你可以打开代码并尝试自己修复它,但并不是所有人都有资源这样做,所以我们会依赖于项目维护者为我们修复它。


Fish 建议我们解释这个问题并说明其紧迫性。她说,这样人们可能会更快地提供帮助,因为大多数(如果不是全部的话)开源维护者所从事的就是协作和沟通,因为这是开源文化的本质。


Fish 建议,在集成开源工具(特别是生产环境)之前一定要进行研究,确保它在出现问题时能够得到良好的维护。


InfoQ 就如何使用开源工具采访了 Hila Fish。


InfoQ:您在选择开源项目时有什么标准吗?


Hila Fish:我会考虑八个关键指标:项目的受欢迎程度、活跃度、安全性、成熟度、文档、生态系统、易用性和路线图。每个关键度量标准都有一些子问题,你可以问自己这些问题并找出答案,这样你就可以逐个指标地评估项目的成熟度级别。


InfoQ:您是如何使用那些标准的?


Fish:举个例子,就拿活跃度这个指标来说,它可以帮助我们大致估计下,这个开源项目修复 Bug/ 发布特性需要多长时间。查看下提交速率是每天、每周,还是每月,看下问题数量、发布数量,这样你就可以很好地了解活跃度。


文档是选择开源项目的另一个重要指标。文档是项目的门户,要看下它是否内容丰富,涵盖了大多数方面,如如何集成、已知问题、功能说明等。有了文档,你在决定是否采用该工具时就更有依据。


原文链接:

https://www.infoq.com/news/2023/12/upsides-downsides-open-source/

2024-01-17 08:005286

评论 1 条评论

发布
用户头像
如何理解隐匿?

2024-01-17 10:22 · 北京
回复
没有更多了
发现更多内容

架构实战营第10期模块八作业

刘博

谷歌研究科学家:ChatGPT秘密武器的演进与局限

OneFlow

JMeter CSV 参数文件的使用方法

Liam

软件测试 测试 Jmeter csv

这样也行,在lambda表达式中优雅的处理checked exception

程序那些事

Java stream 程序那些事

【深入了解系统性能优化】「实战技术专题」全方面带你透彻探索服务优化技术方案(方案篇)

码界西柚

性能优化 JVM 软件开发 4月日更 编程体系

解锁企业数据管理的利器——DataOps

数造万象

海外 SaaS、工具、技术栈实用指南

SaaSLab

SaaS 技术栈 海外市场

华为云网络安全解决方案,云上云下一体助力企业安心发展

IT科技苏辞

走进 RocketMQ(六)事务消息的设计

白裤

Java RocketMQ 事务消息 最终一致性

【异常解决】UnknownHostException: api.weixin.qq.com 的解决方案

No8g攻城狮

小程序 微信 Java EE

AI日课@20230411:Prompt的三个层次和三个“万万没想到!”

无人之路

ChatGPT

华为云EI:引领企业智能化转型,助力全球行业创新

爱尚科技

持续领先同行?看华为云EI如何助力企业智能化转型

爱尚科技

Django笔记八之model中Meta参数的使用

Hunter熊

Python django model meta

Kubernetes 本地持久化存储方案 OpenEBS LocalPV 落地实践下——原理篇

江湖十年

后端 #Kubernetes# Go 语言

Dapr和Rainbond集成,实现云原生BaaS和模块化微服务开发

北京好雨科技有限公司

云原生 #Kubernetes# Baas rainbond 企业号 4 月 PK 榜

MobTech 秒验|极速验证,拉新无忧

MobTech袤博科技

华为云网站安全解决方案:为您的企业保驾护航,助力安心创造未来!

IT科技苏辞

在 plist 中轻松转换两种格式

Java运算符、标识符以及进制

timerring

Java

深度学习:理解卷积神经网络(CNN)的原理和应用

兴科Sinco

人工智能 神经网络 深度学习 自然语言 图象识别

DriveGPT自动驾驶大模型中国玩家首发!1200亿参数,毫末智行出品

Openlab_cosmoplat

人工智能 自动驾驶 机器学习 开源社区 ChatGPT

华为云网站安全解决方案:中小型企业的IT安全利器

IT科技苏辞

如何调整和优化Go程序的内存管理方式?

Jack

在线Plist文件格式转Json文件格式

如何打开 plist 文件

ios 开发 IPA上传

华为云网站安全解决方案,如何保障中小型企业云上云下安全?

IT科技苏辞

SELECT COUNT(*) 会造成全表扫描?回去等通知吧

程序员大彬

Java MySQL

实用技术宝典:MAC地址格式转换多种实现方式

小毛驴的烂笔头

linux命令 linux运维

华为云EI引领行业智能化转型:赋能全球企业,共创智能未来

爱尚科技

走进 RocketMQ(五)高性能文件读写

白裤

Java RocketMQ 消息队列 文件读写优化

采用开源工具:善意推定,但也要做好沟通_开源_InfoQ精选文章