今天我们来读service_lua.c文件。
这个文件很重要,它是模块snlua的源文件,也是各个lua服务节点的制造者。比如:agent服务节点,watchdog服务节点,launch服务节点等。
让我们来看看这个制造者是如何运作的。
拿agent举例说:
gate节点在服务端与新到的客户端连接建立成功之后,会向watchdog服务节点发送一条文本消息,消息内容含有open指令,意在生成两个新的服务节点,分别是client和agent服务节点。
watchdog收到消息后会运行command:open接口:
function command:open(parm)
local fd,addr = string.match(parm,"(%d+) ([^%s]+)")
fd = tonumber(fd)
print("agent open", self, string.format("%d %d %s", self, fd, addr))
local client = skynet.launch("client", fd)
local agent = skynet.launch("snlua","agent",skynet.address(client))
if agent then
agent_all[self] = { agent , client }
skynet.send(gate, "text", "forward" , self, skynet.address(agent) , skynet.address(client))
end
end
执行该接口时,watchdog会