如何强制执行Lua脚本的运行时间限制?

使用dofile在lua中运行一个几乎微不足道的脚本,10000次,在这台机器上需要大约52秒,但如果我运行10000次“lua52 script.lua”,它需要3或4倍的时间。我知道涉及更多的系统调用和其他开销,但我尝试实现的是使用超时运行脚本,比如说3秒,并打印输出。

我的问题是有无限循环的脚本,无论是有意还是无意的,例如:

while(true) do
end

我可以为Lua中的dofile设置超时吗? 我的唯一选择是每次使用timeout(3)调用解释器?

点赞
用户936986
用户936986

没有内置设施,尝试使用lalarm库。

2012-06-29 21:07:12
用户107090
用户107090

如果您的脚本不调用 C 函数,那么您可以使用 _count_ 钩子并设置一个较大的计数值,在钩子内部抛出错误:

local function f() error"timeout!" end
debug.sethook(f,"count",1e6)
while true do end

在应用程序中,在调用 dofile 前设置 _count_ 钩子。

_count_ 钩子每 n 条 Lua VM 指令就会被调用一次。然而,由于无法计算 C 函数占用的时间,因此在上面我提到了警告。

2012-06-30 00:39:27
用户1516484
用户1516484

作为一个新手,在 Lua 方面纠正 lhf 感觉有些不妥,但是这里提供一种方法;将 "count" 传递给 debug.sethook 和将 "c" 或 "call" 传递给它是相同的,正确的掩码可以在执行 n 个虚拟机指令后触发相关函数。

因此,如果要限制从 dofile() 加载的代码的运行时间,请使用以下代码:

local f = function() error("timeout") end
local x,y = xpcall(function()
  debug.sethook(f, "", 1e8)
  local ret = dofile("script.lua")
  debug.sethook()
  return ret
end, debug.traceback)
2012-07-11 03:14:02