当前位置:网站首页>这个困扰程序员50年的问题,终于要被解决了?
这个困扰程序员50年的问题,终于要被解决了?
2022-08-03 03:20:00 【Hollis Chuang】
△Hollis, 一个对Coding有着独特追求的人△

这是Hollis的第 395 篇原创分享
作者 l Hollis
来源 l Hollis(ID:hollischuang)

近日,Google、微软、facebook 和亚马逊终于忍不了了,联合呼吁废除闰秒,什么是闰秒呢?闰秒到底做错了什么?为什么各大互联网公司想要废除他呢?
什么是闰秒
闰秒概念是 1972 年提出的,之所以有这个概念,主要是因为由于潮汐等自然现象的影响,地球的自转速度并不是恒定的。
所以,每隔一段时间世界标准时间「协调世界时(UTC)」会依据地球围绕太阳运动计算的「世界时(UT)」之间出现小的偏差。
所以就需要对协调世界时进行调快或者拨慢1秒来消除这个偏差。
闰秒分为正闰秒和负闰秒,正闰秒表示需要在UTC中插入1秒,负闰秒表示需要在UTC中减少1秒。
闰秒的发生
当科学家们发现”哎呀、今年的地球转的有点快呀,赶紧加一个闰秒来校正一下吧“,这个时间就会发生”正闰秒”。
当闰秒发生时,就需要通过网络时间协议NTP (Network time protocol)来进行时间同步,NTP服务器会一级一级地下发闰秒事件通知直到最边缘的NTP服务器,然后NTP服务器就会把闰秒通知发给客户端的操作系统,由操作系统来处理闰秒通知。
如果你的计算机系统没有开启NTP服务,那么导致的问题就是你的计算机上的机器时间就会比世界时间慢1秒。
如果开了NTP服务的话,就需要操作系统来处理这个闰秒。
闰秒的处理
一般来说,闰秒的调整一般被安排在6月30日或者12月31日,一般会调整在最后一分钟,也就是说,某一年的6月30日的11:59分有61秒。那么计算机系统会如何处理这个闰秒呢?
一般有以下几种方式,如:
1、直接显示23:59:60这样的时间。
2、显示两次23:59:59这个时间。
3、把这一秒平均分到最后一分钟的每一秒钟,也就是11:59还是有60秒,但是每一秒的时长是1+1/60 秒。
不同的操作系统,不同操作系统的不同版本,都会有不同的处理方式,所以我们的代码就需要有足够的鲁棒性来兼容这些闰秒的处理方式,如果没有做好兼容,那么就会发生各种各样的问题。
如需要兼容对23:59:60的处理;如操作会出现两次23:59:59,这对于一些对时间有精确的强依赖的程序来说,可能就会导致致命的问题,尤其是一些依赖时间戳的服务或者工具。
闰秒的危害
50年来,闰秒已经出现过27次,每一次出现都是一片”哀鸿遍野”,如:
2012 年 7 月 1 日零点, Reddit、Mozilla、领英、Yelp 和 Amadeus 等网站宕机数十分钟。
2015 年 7 月 1 日零点,全球约 2000 个计算机网络突然短暂中断;美国洲际交易所被迫中止交易 61 分钟。
2017 年 1 月 1 日零点,Cloudflare 等云服务厂商服务突然崩溃。
因为闰秒的发生是受自然现象影响的,所以他完全无法预测也没有任何规律。对于程序员来说,这种无规律的事情,每次发生都需要进行一次特殊处理,而每一次特殊处理都可能要付出惨痛的代价。
所以,这些国际大厂终于忍不了站出来呼吁废除闰秒了,作为一个程序员,我举双手+双脚赞成!
参考资料:
https://www.qbitai.com/2022/07/36387.html
https://www.163.com/dy/article/HD9ESP2T0531M1CO.html?f=post2020_dy_recommends
https://os.51cto.com/article/345796.html
https://info.support.huawei.com/info-finder/encyclopedia/zh/NTP.html
https://www.zhihu.com/question/27500849
https://qa.1r1g.cn/unix/ask/23322561
往期推荐金额计算用 BigDecimal 就万无一失了?看看这五个坑吧~~
如果你喜欢本文,
请长按二维码,关注 Hollis.

转发至朋友圈,是对我最大的支持。
点个 在看
喜欢是一种感觉
在看是一种支持
边栏推荐
猜你喜欢
随机推荐
ClickHouse常用函数速查大全
# RACE32——高级断点的设置和应用
找不到符号@SuperBuilder,你以为真的是Lombok的问题?
ClickHouse数据类型
Postman如何做接口自动化测试?
leetcode:139. 单词拆分
TRACE32——使用读写断点
用 SQL 做数据分析的十大常用功能,附面试原题解答!!
Jmeter TCP/UDP测试
金仓数据库 MySQL 至 KingbaseES 迁移最佳实践(3. MySQL 数据库移植实战)
VS中使用BugTrap定位程序崩溃点
leetcode:149. 直线上最多的点数
ESP8266-Arduino编程实例-LED点阵驱动(基于Max7219)
云原生(三十一) | Kubernetes篇之平台基本预装资源
网易数帆陈谔:云原生“牵手”低代码,加速企业数字化转型
Useful Monitoring Scripts What you want part1 in Oracle
在VScode里调试ROS程序
大佬们,我有点不明白:为什么oracle-cdc的文档写connector可以做到exactly-o
IDEA如何创建父子工程
【GO记录】从零开始GO语言——用GO语言做一个示波器(二)基于arduino的简易示波器











