微软2022新bug:大量程序员连夜加班,只因日期数据溢出
萧箫 发自 凹非寺
量子位 报道 | 公众号 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
微软2022新bug:大量程序员连夜加班,只因日期数据溢出相关推荐
- 微软 2022 新 bug:大量程序员连夜加班!
星标/置顶 公众号
- 工作10以上老程序员都去哪了?作为新时代的程序员我们该何去何从
在纽约,PyGotham每年召开之际,都会有超过600名程序员聚集在一起讨论工作. 为了让会议更加多元化,组织者尽量邀请一些女性程序员以及各种肤色的程序员. 那么,老程序员都去哪了?他们去了大学教书, ...
- 2022,了不起的程序员日历来啦!
日历一天天地翻过,转眼间 2021 年还剩下一个月了.这一年,小伙伴们有怎样的收获?年初的读书计划.健身计划都落实的怎么样啦!曾经信心满满立下的众多 Flag,如今都实现了没? 来说一个好消息,202 ...
- 微信新表情,程序员的正确使用指南
程序员最幽默(ID:humor1024)整理 近日, 微信悄咪咪上线了一组新表情: 话说, 这组表情包真的是可爱又实用. 就连我这不灵光的脑袋瓜, 马上也有了使用"小指南" 话不多 ...
- 微软史上最惨程序员——一句话错失$20,000,000美元
西雅图IT圈:seattleit [今日作者]Dexter 读书巨慢理事会会长 一个愚蠢的错误决定, 会给你的人生造成多大的损失? 对于今天故事的主人公, 前微软程序员Garry Tan来说, 这个数 ...
- DAPP(分布式应用),区块链新物种,程序员掘金新风口!
DAPP(分布式应用),区块链新物种,程序员掘金新风口! 何玺 百家号02-2211:24 区块链技术正在重构我们的世界.如果你不信,你回头看看过去10年互联网技术对这个世界的改变.今天何玺要聊的,是 ...
- 新浪一位程序员因加班错失年会77万特等奖,该不该给他补上?
据报道,1月16日,某互联网公司在北京召开了2018年的年会,年会现场安排了多项抽奖:有万元现金.苹果产品大礼包.钻戒.出国游机票等,但最让人兴奋的还是特等奖--2000股该公司的股票.目前该公司的股 ...
- GitChat · IT职场 | 新入职程序员的那些「潜规则」
GitChat 作者:李燃 原文: 新入职程序员生存之道 关注微信公众号:GitChat 技术杂谈 ,这里一本正经的讲技术 为什么想讲这个主题? 我觉得我只是说出了一个事实,那就是大家对于新团队的理解 ...
- 为什么程序员下班后只关显示器从不关电脑?
如何查询电脑运行时间? 打开cmd,输入systeminfo,英文条件下输入.回车,系统自动统计相关结果.不仅仅开机时间,系统把所有的信息都给你统计出来了.那么想问问你的电脑多久没关机了呢? 对程序员 ...
最新文章
- SNMP功能开发简介 三 使用DEBUGMSG打印指定的信息
- oracle ORA-14452错误处理
- ContactsContract.Contacts与ContactsContract.CommonDataKinds.Phone的区别
- CAP与Base理论
- saltstack 安装nginx
- Java System类loadLibrary()方法与示例
- fe文件服务器,FE File Explorer
- STM32H743+CubeMX-SPI与DRV8889串行通讯,驱动步进电机
- 函数局部有界性定理_数学分析第四章《函数连续性》备考指南
- 中国互金协会李东荣:力争在法定数字货币等领域深度参与国际标准规则制定
- python语法基础知识第四关第二题_【python基础语法】第4天作业练习题
- c语言从入门到秃头表情包,c语言从入门到放弃表情包 - c语言从入门到放弃微信表情包 - c语言从入门到放弃QQ表情包 - 发表情 fabiaoqing.com...
- 学计算机打字一段话,如何快速学会电脑打字
- 常州大学 计算机与人工智能学院,常熟理工学院新闻网
- 【jquery】收藏本站——添加到浏览器的收藏夹
- 树莓派csi摄像头和usb摄像头_树莓派上用 fswebcam + USB 摄像头拍摄
- Pi-puck的ROS开发之路
- 基于mindwave脑电波进行疲劳检测算法的设计(1)
- jQuery+JSON+jPlayer实现QQ空间音乐查询
- SparkSQL 总结
热门文章
- 【异常】redis.clients.jedis.exceptions.JedisDataException: ERR unknown command ‘PSETEX‘
- 如何对以破折号/连字符开头的字符串进行grep?
- 您是否应该始终偏爱xrange()而不是range()?
- 如何防止批处理文件执行后自动关闭控制台
- rsync 常见错误与解决方法整理
- Redhat7开机图形或文字界面
- 将二叉搜索树转换为有序的双向链表
- 未来十年 智慧交通仍将持续引领城市建设高潮
- zabbix 二次开发之调用api接口获取历史数据
- linux 编译C语言代码后产生OBJ文件的方法