百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 编程网 > 正文

微软2022新bug:大量程序员连夜加班,只因日期数据溢出

yuyutoo 2025-01-12 19:59 1 浏览 0 评论

萧箫 发自 凹非寺
量子位 报道 | 公众号 QbitAI

没想到,2022年的到来,也给微软带来了一个新bug。

随着日期从2021年12月31日跳转到2022年1月1日,不少使用微软Exchange的公司发现,自己写好的新年祝福等邮件,突然发不出去了。

Exchange Server是微软推出的一套电子邮件服务组件,可用于构建企业、高校或机构的邮件系统。简单来说,用它不止能构建“邮箱工作群”,还能协调内部工作流等。

这些公司的邮箱服务器内滞留了大量邮件,有些甚至达到数十万封,面临服务器存储不下的问题。

目前这个bug已经在Reddit热度上千,许多人表示“年都没跨好就在这修bug”:

新年(哔)快乐!

我本来还在度假呢,就给我拉回来处理这个玩意了……

所以到底是怎么回事?

微软2022版“千年虫”

据一位Exchange管理员Joseph Roosen表示,这是一个由于“2022年”的到来而导致的bug。

这个bug的根源,是微软Exchange上面的邮件过滤管理系统(FIP-FS),采用了一种名叫“yymmddHHMM”的有符号变量(Int32,也就是long)存储日期

其中,yymmddHHMM分别指代用两位来存储年(years)、月(months)、日(days)、小时(Hours)、分钟(Minutes)

这个数据类型存在一个问题:

有符号的Int32最多只能存储-2147483647到+2147483647的数据。

然而,从2022年1月1日0时开始,“yymmddHHMM”的yy就已经变成了“22”,超过了Int32所能存储的数据最大范围:

2147483647

22XXXXXXX

于是,在2022年1月1日这天,所有用Exchange服务器发邮件的公司,都收到了这样一条错误提醒

The FIP-FS Scan Process failed initialization. Error: 0x8004005. Error Details: Unspecified Error” or “Error Code: 0x80004005. Error Description: Can’t convert “2201010001” to long.(FIP-FS扫描处理初始化失败……无法将“2201010001”转变为long数据类型)

它最初被一位名叫@miketheitguy的推特用户发现:

由于和“千年虫”一样都是日期给计算机带来的bug,这次bug也被一些Exchange管理员命名为Y2K22

其中,Y2K指的是著名的“千年虫”问题,由于部分计算机程序只采用两位十进制数表示年份,在跨世纪时就会出现错误的结果;22指的则是2022年。

这个bug在不少Exchange Server版本中都出现了相同的问题,包括2016和2019等。

目前,微软的Exchange团队正在紧急修复中。

他们表示,几天后会发布一个Exchange Server更新,里面将用一个更大的变量类型来保存日期。

然而在这之前,使用Exchange Server的公司们必须想办法把邮件发出去。

一些权宜之计

微软团队表示,如果有非常紧急的邮件需要发送,需要先关掉Exchange中的FIP-FS功能。

这是个Exchange上的垃圾邮件过滤器,平时会用来扫描邮件中自带的恶意软件、或是垃圾邮件。

目前微软官方也提供了一些禁用或绕过恶意软件扫描的方法。

然而,这样操作的后果是公司邮箱“可能收到更多垃圾邮件”。

对此有网友调侃,如果微软在修复中把有符号变量改成无符号变量,那么数据的表示范围就会变成0~4294967295,Exchange邮箱又可以用到2043年了。

除此之外,目前Reddit网友还给出了一些其他的解决方案。

例如,有网友发布了一个非官方的自定义脚本,可以将日期回滚到2021年,但他对此表示,一切风险需要使用者自己承担。

如果还没想好怎么解决你的Exchange邮箱系统问题,可以先用上面这些方法试一试。

非官方脚本:
https://blog.markdepalma.com/?p=810

微软官方答复:
https://techcommunity.microsoft.com/t5/exchange-team-blog/email-stuck-in-transport-queues/ba-p/3049447

参考链接:
[1]https://www.reddit.com/r/sysadmin/comments/rt91z6/exchange_2019_antimalware_bad_update/
[2]https://www.bleepingcomputer.com/news/microsoft/microsoft-exchange-year-2022-bug-in-fip-fs-breaks-email-delivery/
[3]https://www.neowin.net/news/y2k22-bug-microsoft-rings-in-the-new-year-by-breaking-exchange-servers-all-around-the-world/
[4]https://twitter.com/miketheitguy/status/1477097527593734144

— 完 —

量子位 QbitAI · 头条号签约

关注我们,第一时间获知前沿科技动态

相关推荐

字节跳动官方出品的免费图标库,超好用还能自定义修改

现在很多企业公司或品牌都会将自己开发的设计素材开放出来,像是图标集、字体或是网页框架等等,使这些项目可以被更多人使用,或是在开源的情况下创造出更多可能性,当然一方面也能提高被看到的机会。之前介绍过IB...

微信底部不起眼的图标,还藏着设计师的这些小心思,网友:贴心

每天至少要打开十几次的微信,你注意过底部的小图标吗?可能有些读者会说了,不就是几个小图标吗?你发现没:选中的图标选项框是实心图标,但是没有选中的就是空心图标。为什么会这样设计呢?所以,我们今天就来聊聊...

ppt常用小图标去哪里找?3个矢量素材网站推荐!

ppt是一个注重可视化表达的演示载体,除了高清图片,ppt中另一类常用的素材是各种小图标,也叫矢量图标,巧妙运用小图标能提升整体美观度和表现力,那么ppt常用小图标去哪里找呢?...

手机右上角的状态栏,如果出现了这些小图标,记得一定要关闭

文|技术探索者编辑|技术探索者...

Win10设置应用更新:升级“关于”页面,主页图标可跟随主题色

IT之家12月24日消息,科技媒体WindowsLatest昨日(12月23日)发布博文,报道称Windows10系统正整合两项“新”功能/特性,包括色彩更丰富的设置H...

全网最炫酷、最华丽、最好看的动画图标库

很多小伙伴一直苦恼找不到合适自己使用的动画图标,今天TJ君要给大家分享一个...

电脑任务栏的网络小图标,就能告诉你不能上网的真正原因是什么?

我们在使用电脑时,经常遇到电脑突然就不能上网了,特别是着急上传文件或资料的时候,偏偏在关键时候掉链子。其实,电脑真的很智通,只是我们不在意电脑告诉我们的重要信息,所以就只能干着急了。1、正常有线网络连...

建议收藏的7个高质量图标网站,一网打尽图标素材

大家好,这里是@秋叶PPT图标是PPT制作中经常用到的元素之一,其比文字生动,比图片简洁的特性,应用在PPT中可以极大地提高页面的可阅读性,从而深受广大PPT爱好者喜爱。...

软网推荐:轻轻松松制作与处理图标

在制作软件、网页、多媒体作品时,常常会涉及到各种各样的图标。要制作这些图标,我们当然可以使用Photoshop这样的专业软件,但用该软件制作,操作不见得简单。其实,我们只需使用一个便携版的AniFX...

服务器安全:CentOS 7中安装CSF防火墙

提到服务器的安全性,有人可能会觉得一般服务器的操作系统相对个人PC的安全性更高,更难以破解,尤其是CentOS操作系统自身也比较安全,但是因为服务器内的信息更为关键,所以笔者建议还是不要让它“裸奔”,...

什么是基因突变,乳腺癌常见的基因突变有哪些?

基因突变当一个细胞生长和分裂时,它会复制它的DNA。有时新细胞中的DNA与原始细胞不同。这叫做突变。你生来就可能有遗传的,或遗传的,你从你的父母那里继承下来的突变。如果他们中的一个生来就有一个基因,他...

.NET 7 AOT 的使用以及 .NET 与 Go 互相调用

目录...

6 张图带你彻底搞懂分布式事务 XA 模式

XA协议是由X/Open组织提出的分布式事务处理规范,主要定义了事务管理器TM和局部资源管理器RM之间的接口。目前主流的数据库,比如oracle、DB2都是支持XA协议的。...

【云原生】Prometheus AlertManager讲解与实战操作

一、概述Prometheus包含一个...

Win10桌面/手机版最深层次开发功能挖掘

IT之家讯Win10开发者预览版为我们提供了一个Win10大框架的早期概览,使开发者与热心用户都可以提前感受Win10带来的新特性,尝试新工具,而作为开发者,最关心的莫过于Windows多平台通用应...

取消回复欢迎 发表评论: