通过SSH进行Lua脚本,包括文件输入输出操作。

我试图在远程运行脚本(远程服务器为B)。 当我在A服务器本地运行脚本时,我得到了预期的结果。 但是,当我通过SSH从A服务器运行脚本到B服务器时,出现以下错误:

/usr/bin/ssh admin@server.domain.com "lua/rpi.init"
lua:lua/rpi.init:8:尝试索引闭合值“logFile”(值为null) 堆栈跟踪:
        lua/rpi.init:8: in function 'logMsg'
        lua/rpi.init:47: in main chunk

#!/usr/bin/env lua
local f = assert(io.popen("sudo netstat -a | grep ^tcp[^6] | grep LISTEN | grep [^0-9]22[0-9][0-9]", 'r'))
local ports22 = {}
local logFile

function logMsg(msg)
        logFile = io.open("logs/pi.init.log", "a+")
        logFile:write(os.date("%b %d %Y %X ") .. tostring(msg) .. "\n")
        logFile:close()
end

function getPorts22()
logMsg("Getting available ports...")
while true do
        line = f:read()
        if line == nil then break end
        port = string.sub(line, 40, 44)
        table.insert(ports22, port)
end
f:close()
table.sort(ports22)
end

function getNextOpenPort22()
        local openPort = 2222
        if #ports22 == 0 then
                logMsg("Returning port :" .. openPort)
                return openPort
        end
        for i=1, #ports22 + 1 do
                if tonumber(ports22[i]) == openPort then
                        openPort = openPort + 1
                else
                        logMsg("Returning port: " .. openPort)
                        return openPort
                end
        end

end

function printPorts()
        msg = table.concat(ports22, ", ")
        logMsg("Found ports in use: " .. tostring(msg))
end

logMsg("Script called to run.")
getPorts22()
printPorts()
print(getNextOpenPort22())

是否可能通过SSH(bash,lua或其他方式)运行脚本并让它们在远程机器上执行io操作?

此外,从远程脚本返回值到本地主机的最佳方法是什么? 我通过调用print()来返回我的脚本的值,以便我的本地脚本实际使用。

点赞
用户1442917
用户1442917

您出现此错误是因为io.open调用返回了一个空值和一个错误消息。您可能需要将以下行更改为以下内容:

local logFile, err = io.open("logs/pi.init.log", "a+")
if not logFile then error(err, 2) end

io.open调用不成功时,这将打印错误消息。在您的情况下,可能是由于不存在的logs文件夹、权限不足或其他原因造成的;错误消息应该指引您朝正确的方向前进。

2015-08-01 05:53:18