Node.js   发布时间:2022-04-24  发布网站:大佬教程  code.js-code.com
大佬教程收集整理的这篇文章主要介绍了node.js – 使用libfaketime时,setTimeout在Mac OS和Linux上的行为有所不同大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。
当使用libfaketime来改变进程的时间速度时,setTimout设置的超时将根据在 Linux下运行时更改的时间到期,但是根据在Mac OS下运行时的原始系统时间.

在Mac OS中:

DYLD_INSERT_LIBRARIES=src/libfaketime.1.dylib DYLD_FORCE_FLAT_NAMESPACE=y FAKETIME="@2020-12-24 00:00:00 x3600" node

> setTimeout(() => {console.log('hello');},3600 * 1000); // Takes an hour

在Linux中:

LD_PRELOAD=src/libfaketime.1.so FAKETIME="@2020-12-24 00:00:00 x3600" node

> setTimeout(() => {console.log('hello');},3600 * 1000); // Takes a second

在研究这个问题时,我注意到libc的clock_gettime函数在Linux下由node.js(libuv?)轮询,但在Mac OS下运行时不调用函数. (我在libfaketime函数添加了一些printfs)

node.js(libuv?)的实现有什么不同,导致Mac OS和Linux之间的行为差​​异?为什么存在这种差异?

我做的另一个观察是,当使用libfaketime冻结时间时,setImmediate和setTimeout(cb,0)的行为在Linux下的不同之处在于回调在使用setImmediate时运行,但在使用setTimeout(cb,0)时不运行.

解决方法

这绝对是libuv的一个不同之处.达尔文不是 support CLOCK_MONOTONIC*,因此 mach_absolute_time() must be called是为了获得当前时间.这最终会绕过libfaketime,导致客户端代码在OS X上实时运行.

大佬总结

以上是大佬教程为你收集整理的node.js – 使用libfaketime时,setTimeout在Mac OS和Linux上的行为有所不同全部内容,希望文章能够帮你解决node.js – 使用libfaketime时,setTimeout在Mac OS和Linux上的行为有所不同所遇到的程序开发问题。

如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。
标签: