English
联系我们
网站地图
邮箱
旧版回顾



胶南大珠山

每一行代码都令人敬畏吗?蚂蚁代码鸡蛋炸出一个圈子

    本文来自微信公众号:InfoQ(ID:infoqchina),作者:覃云、徐川,编辑:小智。对于开源项目来说,一个细微的改动就会影响到无数使用该项目的产品、公司、生产环境。阿里是中国开源的先锋公司,对于事故的处理也一直都很有担当,阿里云“敬畏每一行代码,敬畏每一份托付”曾是公关文的典范,但 Antd 项目彩蛋变炸弹这件事儿,我们却只能表示遗憾和可惜。开源项目的责任如何看待?怎样避免类似事件再次发生?12 月 25 日,正当人们沉浸在节日的气氛中时,部分开发者突然发现他们开发的 Web 网页的界面发生了变化,按钮上方出现“积雪”,经过探索发现这是前端 UI 组件库 Ant Design(简称 antd)提前埋入一个未经声明的“彩蛋”,事件迅速发酵,引起了巨大争议。 事件背景 现在让我们再来回顾一下整个事件的发展过程:12 月 25 日上午,Antd 的用户发现网站上一个正常的按钮上方出现了“积雪”的 logo,如下图所示:经过查看,Antd 的用户在工作后台上发现按钮的 class 多出一个 chrismas,title 变成 Ho Ho Ho,然后再去查看 antd 源码,发现:最开始,开发者以为是被黑客代码植入了,在反复检查之后才确定是代码中埋入了定时的“圣诞节彩蛋”。不久,此事就开始在知乎和 Antd issue 上引起讨论,很多开发者表示愤怒与不满。很多开发者认为,Antd 是一个通用库,不应该在里面加彩蛋,尤其 Antd 大都是 2B 的,它的用户对安全、稳定、可控性的要求更高,发生一些细微的错误都可能影响一个公司的业务,再者,如果今天被随意加入一个彩蛋,那么明天就可能被人引入病毒,这让开发者很是恐慌。最后,这个彩蛋没有下线机制,让开发者无所适从。有开发者半开玩笑说,如果不是圣诞节而是中国的传统节日也许就不会引起那么大的争议了,因为有些单位有明令禁止过洋节的规定,试想一些,如果这些禁止过洋节的网站(如个别政府网站)的按钮都是圣诞节的 logo,后果可想而知。更有传言,个别程序员因为此事被用来祭天。 当事人的回应 由于事态持续发酵,昨天下午,在 Antd 开源库中加入这些彩蛋代码的工程师偏右在知乎上对此事做出了回应:Ant Design 圣诞彩蛋起源自 2018 年 9 月 10 日我的一次提交:,并增加 Ho Ho Ho! 的浏览器默认提示信息。这完全是我个人的一意孤行且愚蠢的决定,是我的错误给大家造成了不良影响,非常抱歉。同时,他还给出了修复这个问题的方案:目前圣诞节彩蛋影响的 Antd 版本包括:3.9.3、3.10.0~3.10.9、3.11.0~3.11.5为此,Antd 团队发布了修订版本:3.9.4、3.10.10、3.11.6,相关用户只需更新至相应的版本即可,使用了语义化版本的直接重新安装 node_modules 并重新下载即可。蚂蚁前端负责人玉伯也在知乎回应(摘录):这件事确认是由我们在代码中预埋的彩蛋导致,现在明确认定这一举动是错误的。这个彩蛋有多么欠妥我们不再赘述,对大家造成的各种影响,antd 开发团队致以诚挚的歉意。感谢所有热心用户提出的批评指正,感谢你们的中肯建议。开源得益于大家的信任,我们会立刻开展复盘并深刻吸取这次教训,并重新 review 代码更新评审机制。后续 antd 代码库里不会再加入与功能无关的代码,请大家持续监督。不过,关于后续处理等,InfoQ 联系了蚂蚁金服相关人士,他们不愿公开。 如何看待开源项目的责任 如今的开源,早已不是自由软件时代的理想主义。很多公司都参与到开源中来,它们的动机,除了一些回馈社区和分享精神外,还掺杂着商业和利益上的考量,其中包括:通过领导关键开源项目,成为某行业事实标准,从标准中获取利益;开源核心代码,基于核心代码提供付费的咨询和外包、资源服务;通过开源项目,提升团队成员的技术能力和凝聚力,打造技术品牌,方便对外做技术招募。不过,在遍地商业化的开源里,前端的开源又有其特殊性,因为前端的技术很难直接带来利益,上面的三种好处里,最多占第三条。这导致前端开源有一定的随意性,之前在前端开源领域也发生过人为原因的影响非常大的恶意事件:left-pad 事件:作为很多项目的依赖的作者基于个人原因将项目从 NPM 包管理器中删除,导致很多项目和网站无法正常工作;event-stream 事件:一个令人尊敬的开源作者因为项目众多缺人维护,将项目权限转送他人后竟然被植入比特币钱包后门。前端开源代码缺乏商业化元素,让一部分人认为随意修改代码并没有责任,对于一些个人的小型项目来说这么说并没有错。antd 的修改本身并不会带来直接损害,但在宗教性节日在生产环境做无法下线的“彩蛋”,显然欠缺考虑,并带来一系列的间接损害。而且,antd 在宣传时自称为企业级开源项目,这样随意修改代码显然与企业级的承诺相违背。同时,antd 是公司级的开源项目,这样欠缺考虑的修改也损害了背后公司在开源上负责任的形象。最后,能力越大,责任也越大,antd 作为很多项目的底层依赖,在做功能修改后未告知用户,在用户发现后没有迅速解决问题而是用不当言辞继续激怒用户。这些才是我们对于 antd 批评的主要原因。 怎么避免类似事件再次发生? 从 antd 的 issue 区可以看到,事件在很短时间内就演变成一场狂欢,这其中固然有因为当事人在 Github 上的回应不当导致事件失控的原因,也不乏一些人带节奏或者借题发挥,这显然已经超出了界限。在这里,我们也呼吁读者不要参与,不要传播那些恶意段子图。现在,我们应该思考的,是怎么避免类似事件再次发生。经过此次事件后,想必国内公司在操作开源项目时会更加谨慎。对于底层依赖型的代码,我们要尽量保持稳定,不要随意修改代码。其次,在修改导致任何功能变化的代码后,一定要在 changelog 里体现出来,这才是负责任的做法。最后,完善开源项目的管理流程,要有人能够把关代码,不让一些欠缺考虑的代码合并到主线。如果真想做好开源,这些是必须要做到的。对于开源项目的用户来说,要跟踪所有依赖代码的所有更改显然是不太可能做到的,这就要求在技术选型时要慎之又慎,在不同的场景选择不同的技术,在面对严肃的场景时,一定要选择成熟 / 稳定 / 可靠的技术,这也能从一定程度上避免问题。在面向年轻用户时,选择更新潮的技术,这样即使出现问题也有更高的容忍度。本文来自微信公众号:InfoQ(ID:infoqchina),作者:覃云、徐川,编辑:小智。

    

    

     *文章为作者独立观点,不代表网立场

     本文由 InfoQ 授权

     网 发表,并经网编辑。转载此文请于文首标明作者姓名,保持文章完整性(包括注及其余作者身份信息),并请附上出处(网)及本页链接。原文链接:

    

    

     未按照规范转载者,保留追究相应责任的权利

    

    

     未来面前,你我还都是孩子,还不去下载 App 猛嗅创新!

当前文章:http://www.onclipevent.com/vtmvp/274526-56184-62678.html

发布时间:01:41:20

广州设计公司  广州产品设计  广州产品设计  广州外观设计  工业设计  广州设计  广州产品设计  广州产品设计  工业设计  广州设计公司  万彩吧  

{相关文章}

全建总部召开直销会议:主持人说,秘方治疗疑难病|全建新浪财经uuuuuuu

    资料来源:每日经济新闻。主持人从山东青岛引进全健的秘方,治疗全家疑难杂病。12月26日上午,《每日经济新闻》记者赴天津市武清市参观泉建天然医药科技发展有限公司(以下简称泉建公司)总部。在昨天被Clove博士的文章“十亿健康帝国全建,中国家庭在其阴影”问及频繁发生的传销和安全事件后,今天全建公司正常工作,其总部正在举行直销系统“全记”的1000人特许人会议。集旅游资讯网_空调资讯网团商德系统启动大会暨隆重节日”。现场播放的宣传片宣布,奄奄一息投资于华北、华东、华南、东北等医疗行业,并宣布奄dc资讯交流网_易方达科汇网奄一息投资于奄奄一息的奄奄一息的奄奄一息的奄奄一息的奄奄一息的奄奄一息。网站上,主持人多次提到“健康”、“中药秘方”等词。主持人说:“我们过去常常认为火疗法就是全剑,我们过去常常认为治病就是全剑。为什么我们几年来一直使用保健品而没有任何效果巨潮资讯官网_苏杭天气网,为什么火这么神奇?”据现场人员介绍,全健的秘方产品治愈了来自山东省青岛的“紫茜老师”家属的疑难病症。前党的亲属现在是商德体系的高级成员。(本文来自各个频道网络)免责声明:由媒体合普通话太普通_重庆网络大学网成的内容来自媒体,公共设施用地_猫头鹰的特点网版权属于原作者,请联系原作者并获得复制许可。本文的观点仅代表作者本人,而非新浪的立场。浙江树人大学怎么样_浙江中学网如果内容涉及投资建议,仅供参考,不作为投资的依据。投资是有风险的,所以我们进入市场时需要谨慎。责任编辑:陈鹤群

专题推荐

相关新闻


© 1996 - 螟蛉有子网 版权所有   联系我们

地址:北京市三里河路52号 邮编:100864

https://4l.cc/articlelist-401.htmlhttps://4l.cc/articlelist-376.htmlhttps://4l.cc/articlelist-365.htmlhttps://4l.cc/articlelist-344.htmlhttps://4l.cc/articlelist-410.htmlhttps://4l.cc/articlelist-338.htmlhttps://4l.cc/articlelist-335.htmlhttps://f49.in/article-45182.htmlhttps://f49.in/article-463.htmlhttps://f49.in/article-42897.htmlhttps://f49.in/article-44241.htmlhttps://f49.in/article-44242.htmlhttps://f49.in/article-430.htmlhttps://f49.in/article-2512.htmlhttps://f49.in/articlelist-364.htmlhttps://f49.in/articlelist-349.htmlhttps://f49.in/articlelist-344.htmlhttps://f49.in/articlelist-440.htmlhttps://f49.in/articlelist-331.htmlhttps://55t.cc/wapindex-1000-331.html?sid=-3https://55t.cc/articlelist-331-0.html?action=class&getTotal=34https://55t.cc/article-65.htmlhttps://55t.cc/articlelist-350.htmlhttps://55t.cc/articlelist-441.htmlhttps://www.c8.cn/zst/qlc/sslh.htmlhttps://www.c8.cn/zst/pl3/qmfb.htmlhttps://www.c8.cn/zst/6cai/sxzs.htmlhttps://www.c8.cn/zst/6cai/tmhs.htmlhttps://www.c8.cn/zst/6cai/simzs.htmlhttps://www.c8.cn/zst/6cai/emzs.htmlhttps://www.c8.cn/zst/qxc/jozs.htmlhttps://www.c8.cn/zst/qxc/dzbbzbzs.htmlhttps://www.c8.cn/zst/ssq/chusanzs.htmlhttps://www.c8.cn/zst/3d/elyzs.htmlhttps://www.c8.cn/zst/bjkl8/dswzs.htmlhttps://www.c8.cn/zst/cqkl10/sihdw.htmlhttps://www.c8.cn/zst/cqkl10/hzzs.htmlhttps://www.c8.cn/zst/19.htmlhttps://www.c8.cn/zst/46.htmlhttps://www.c8.cn/jihua/sckl12.htmlhttps://www.c8.cn/jihua/hlj11x5.htmlhttps://www.c8.cn/jihua/pk10.htmlhttp://www.easeid.cn/html/productlist/list-116-1.htmlhttp://www.easeid.cn/html/productlist/list-123-1.htmlhttp://www.easeid.cn/content/?314.htmlhttp://www.easeid.cn/html/news/2013-5-20/217.htmlhttp://www.easeid.cn/html/productlist/list-7-2.htmlhttp://www.easeid.cn/html/product/2013-6-10/387.htmlhttp://www.easeid.cn/html/about/about-110_2.htmlhttp://www.easeid.cn/html/news/2013-6-3/289.html