我有一个rake任务,它解析一个流API并将数据输入到数据库中。流API是实时提要,为了让实时数据进入数据库,rake任务应该持续运行。一旦调用rake任务,它就会连续运行并解析数据。现在我已经启动了rake任务,它正在运行。问题是,如果我关闭终端或重启服务器,rake任务将停止。因此,我需要linux中的一个脚本(类似于用于启动或停止apache服务器的脚本),它执行以下操作:
1. start the rake task by calling rake command (rake parse:stream) from the RAILS-ROOT (application director
我正在从不同的来源收集数据,并希望获得尽可能准确的时间。除了timeit,还有time。monotonic,time.time,有没有类似于Linux的“实时”方法? (我知道,这取决于操作系统(open suse),多任务/多用户系统很难像实时系统那样精确,但在某种程度上,我希望在正常的Linux系统上尽可能精确地测量时间。) 使用time.time方法的示例。如果我在一个循环中使用这个方法,在这个循环中我安装了一个睡眠4秒(从秒8开始),那么度量是: absolute distance to next measurement
8.04026126861572
当我在linux下测试perl脚本并使用time sh -c来测量所花费的时间时,我得到了一个奇怪的结果:
real 14m11.903s
user 34m39.319s
sys 16m54.074s
这意味着实际花费的时间甚至少于用户时间。而我自己在视觉上计算时间,脚本花费的时间不到34分钟,实时更接近我所看到的。有没有人对此有任何线索?谢谢。