假设我的程序在正确配置为处理 leap seconds 的 Linux 机器上运行.该配置是如何完成的(NTP,配置文件)不应该与这个问题相关。
实际上,内核将在 UTC 月末插入一秒或跳过一秒。这对 gettimeofday(2) 读取的时间值有影响。重复或跳过该月的最后一个 UTC 秒。闰秒期间的时间示例读数为 listed here .
我的问题:在 C/C++ 程序中,我如何知道月末是否会出现闰秒,以及在哪个方向出现闰秒。那么如何在linux上实现如下功能
int leap_seconds_scheduled_for_end_of_month() {
if (/*kernel_will_insert_extra_second?*/)
return 1;
if (/*kernel_will_skip_over_last_second?*/)
return -1;
return 0;
}
如果月末是遥远的 future ,如果结果不正确也没关系。 (到目前为止,就我而言,是 >=2 秒)答案必须在可能的闰秒之前的最后一秒内正确 (*),即该月最后一天的 23:59:58 UTC。闰秒发生后我才知道是不够的,因为我必须提前做好准备。
我一直试图在 sysfs 或 procfs 中找到任何闰秒指示器,但到目前为止都没有成功。
(*) 当然,如果内核本身仅在闰秒发生前的一小部分了解闰秒,例如由于上个月整个NTP服务都中断了,所以答案不可能是正确的。没关系。
最佳答案
内核保留一个标志,定义是否在当前 (UTC) 日结束时添加(或删除)闰秒。如果支持此项,则在闰秒剩余时间不到一天时由 ntpd 设置。
所以你基本上可以通过检查这个标志得到一天的闰秒警告,假设 (a) 你的 ntp 守护进程从它的来源注意到它,并且 (b) 你的 ntp 守护进程正确地确定你的内核支持这个。
我不认为标志是通过 sysfs 或 procfs 公开的;但是很容易通过 adjtimex 系统调用从 C 中检索:
#include <sys/timex.h>
#include <stdio.h>
int main(int argc, char **argv)
{
struct timex buf;
int res;
buf.modes = 0;
res = adjtimex(&buf);
if(res < 0) {
perror("Error calling adjtimex");
return 1;
}
printf("clock status: %i\n", res);
return 0;
}
如 adjtimex(2) 所示,如果闰秒即将到来,则结果为 1 或 2:
On success, adjtimex() returns the clock state:
#define TIME_OK 0 /* clock synchronized */ #define TIME_INS 1 /* insert leap second */ #define TIME_DEL 2 /* delete leap second */ #define TIME_OOP 3 /* leap second in progress */ #define TIME_WAIT 4 /* leap second has occurred */ #define TIME_BAD 5 /* clock not synchronized */
关于c - 如何查看linux内核是否会在月底插入闰秒,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/26202730/