raj*_*bzz 5 linux macos settimeout node.js libuv
当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
Run Code Online (Sandbox Code Playgroud)
在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
Run Code Online (Sandbox Code Playgroud)
在调查这个问题,我注意到libc的clock_gettime功能是由Node.js的(libuv?)Linux下接受调查,但在Mac OS上运行时,不调用该函数.(我printf在libfaketime函数中添加了一些内容)
node.js(libuv?)的实现有什么不同,导致Mac OS和Linux之间的行为差异?为什么存在这种差异?
我做的另一个观察是,使用Linux libfaketime的行为冻结时间setImmediate并且setTimeout(cb, 0)在Linux下的不同之处在于回调是在使用setImmediate时运行而不是在使用时运行setTimeout(cb, 0).
| 归档时间: |
|
| 查看次数: |
115 次 |
| 最近记录: |