服务器之家:专注于VPS、云服务器配置技术及软件下载分享
分类导航

Linux|Centos|Ubuntu|系统进程|Fedora|注册表|Bios|Solaris|Windows7|Windows10|Windows11|windows server|

服务器之家 - 服务器系统 - Linux - Unix这颗大雷,真的会让电子设备瘫痪吗?

Unix这颗大雷,真的会让电子设备瘫痪吗?

2024-01-02 14:10FreeBuf.COM Linux

新年伊始,万象更新,今天不发那些网络安全新闻,聊聊轻松点的话题,给大家在元旦假期里解解闷。业内一直盛传的Unix时间的雷,真的会让全球电子设备瘫痪吗?

新年伊始,万象更新,今天不发那些网络安全新闻,聊聊轻松点的话题,给大家在元旦假期里解解闷。业内一直盛传的Unix时间的雷,真的会让全球电子设备瘫痪吗?

Unix这颗大雷,真的会让电子设备瘫痪吗?

昨天,几个安全圈好友聚在一起喝酒,不知怎么就聊到了“千年虫”的问题。当年开发计算机操作系统的那帮大神们亲手埋下的雷,在时间的流逝下慢慢爆出了各种匪夷所思的安全BUG。千禧年Y2K的雷是Windows,而Unix的雷则是在2038年爆发。

Unix的雷是怎么埋下的?

话说再1969年,贝尔实验室的大神Ken Thompson曾利用老婆回娘家的假期,开发了一个操作系统,它叫Unix。没错,就是咱们现在使用的那个Unix,开发它大概用了三周(夸张)。看来,老婆回娘家可以大幅提升已婚男人创造力,这在全球范是统一的。

在开发过程中,他遇到了一个严重的问题:如何在Unix中表示日期和时间?最简单的办法是用一个字符串来表示,例如1970-09-17 00:00:30.751,但这明显不是最好的办法。最后Ken决定用一个整数来表示日期和时间,也就是Unix 纪元时间,并将1970年1月1日00:00:00设定为开始时间。

Unix这颗大雷,真的会让电子设备瘫痪吗?

所以Unix 系统的时间计算方法其实是用秒数来表示系统时间。换句话说当下的时间(2024年1月1日00:00:00)是从1970年1月1日00:00:00走过多少秒的时间,即系统时间 = 基准时间+秒数。感兴趣的朋友,可以访问time.is/Unix网站,可以知道从1970年1月1日00:00:00到现在一共过去了多少秒。

由于Ken将Unix时间确定为32位整数,这就导致一个很严重的系统BUG,32位的有符号整数最大值是2147483647(距离1970年1月1日00:00:00走过了2147483647秒),简单换算下Unix时间为2038年1月19号 03:14:07 UTC,再往后就没了。

一旦越过这个时间最大值,Unix系统时间将会在内部被表示为一个负数,并造成程序无法工作,因为它们无法将此时间识别为 2038 年,甚至还有可能调回到 1970 年。这让很多人想起了千禧年的“千年虫(Y2K)”事件,因此Unix系统时间问题也被称为Y2K38。

Unix这颗大雷,真的会让电子设备瘫痪吗?

当然这也不能完全怪Ken。毕竟那时候主流计算机还都是使用16位,所以使用32位整数来设定时间已经够够的了。在他看来,Unix系统能不能活到2000年都是个问题,更别提2038年。但谁能想到,Unix系统竟是如此的强悍,不仅可以和Windows相抗衡,还统治了服务器端的OS市场,在计算机操作系统的发展史上占有重要的地位,此后“简洁,一致性,易使用”被很多开发人员奉为圭臬。

问题很严重吗?

扯远了。。

其实解决方案也不复杂,将32 位有符号整数修改成 64 位有符号整数(时间长度近300亿)。目前Linux内核开始全面支持64位时间戳的系统调用,记得在升级之后看看原来的程序和库是否使用32位编译,如果是则需改成64位,否则依然会产生溢出问题。

虽然很多文章将这一问题描述地很严重,甚至会导致大部分电脑瘫痪无法工作。但我们认为,这样的情况并不会出现。距离2038年还有整整14年的时间,以现在电子设备迭代的速度来看,那时候还有没有32位的电脑都是个未知数。

其次,从千年虫事件来看,最终结果没有产生非常严重的影响,部分安全问题都控制在小范围内,尤其是并且对现实世界产生严重影响,相信Y2K38也不会有太过严重的后果。Unix对这一BUG也是心知肚明,不可能找不到一个妥善的解决办法。

最后,祝大家元旦快乐。2024年,你我皆是黑马!(狗头保命)

资源来源于互联网

原文地址:https://www.freebuf.com/articles/388350.html

延伸 · 阅读

精彩推荐
  • LinuxBash 基础知识系列 #6:处理字符串操作

    Bash 基础知识系列 #6:处理字符串操作

    在大多数编程语言中,你都会找到字符串数据类型。字符串基本上是一组字符。 但 Bash Shell 有所不同。字符串没有单独的数据类型。这里一切都是变量。...

    Linux中国32023-08-01
  • LinuxLinux usermod 命令的使用

    Linux usermod 命令的使用

    这篇文章主要介绍了Linux usermod 命令的使用,帮助大家更好的理解和学习Linux,感兴趣的朋友可以了解下 ...

    Dabelv3242020-08-17
  • LinuxDebian LINUX 基础知识介绍

    Debian LINUX 基础知识介绍

    IP地址设置: /etc/network/interface // 动态DHCP获得 # 启动系统激活设备 # Loop回环地址 auto lo iface lo inet loopback # 启动系统激活设备 # 网卡eth0设置为DHCP类型 auto e...

    Linux教程网3022020-04-15
  • LinuxLinux下升级python和安装pip的详解

    Linux下升级python和安装pip的详解

    今天小编就为大家分享一篇关于Linux下升级python和安装pip的详解,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小...

    小飞侠-23812022-08-18
  • Linux手动为LiteSpeed安装eAccelerator和XCache的方法分享

    手动为LiteSpeed安装eAccelerator和XCache的方法分享

    感觉很久没发VPS教程类的文章了,正好最近又开始玩起了LiteSpeed,就把安装eAccelerator和XCache的方法跟大家简单分享一下吧 ...

    Linux教程网5272019-12-17
  • Linux浅谈生产者消费者模型(Linux系统下的两种实现方法)

    浅谈生产者消费者模型(Linux系统下的两种实现方法)

    下面小编就为大家带来一篇浅谈生产者消费者模型(Linux系统下的两种实现方法)。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编...

    Linux教程网10092021-12-20
  • Linux运维人员必须知道的十个系统进程

    运维人员必须知道的十个系统进程

    kswapd0系统定时唤醒kswapd,检查内存是否紧张,如果不紧张,则睡眠,在kswapd中,有2个阀值:pages_hige,pages_low,空闲内存页数量低于pages_low的时,kswapd进程会扫...

    步步运维步步坑9802023-12-13
  • Linux用开源的 Darktable 进行照片处理

    用开源的 Darktable 进行照片处理

    如果你拍摄的照片值得处理,那么你可以看看 Darktable 为你提供了什么。...

    Linux中国8672021-12-19