认识skynet(3)--例子代码分析

Skynet启动examples/config脚本,通过start=”main”开启了第一个Skynet的服务main.lua,这个文件也在examples中,我们看看这个文件写的什么:

认识skynet(3)--例子代码分析_第1张图片
例子源码


第一行先引用skynet这个库,这个是用lua写的,即lualib/skynet.lua。里面定义了这些接口:

skynet.start(): 用于"服务(service)"的入口函数,加载lua的service服务时会先运行这里的代码,它调用了luaclib-src/lua_skynet.c里面的callback(),最终调用Skynet的框架skynet_callback()来设置回调函数。

skynet.newservice(): 用于启动一个lua写的"服务(service)",省略掉.lua后缀名。它调用了skynet.call(), 然后skynet.call()调用luaclib-src/lua_skynet.c里面的send(), 最终调用Skynet的框架的skynet_send()压入队列。skynet.call()用于发送一条消息给Skynet的框架。消息会压入队列,等待Skynet框架的调度。

skynet.exit(): 移除"服务(service)",通过skynet.send()发送一条消息给Skynet框架来移除lua的这个"服务(service)"。

skynet.monitor(): 用于监视"服务(service)",看它是否关闭。


main.lua一共打开了四个服务:

1、service_mgr这个是系统的模块,用于管理服务。

2、console这个是系统的模块,用于输出。

3、simpledb这个是例子的模块,用于管理Key–Value数据。

4、watchdog这个是例子的模块,用于监视socket端口,等待数据。


main.lua没有调用其它函数, 加载完服务, 它也就完成了任务, 所以它最后调用了skynet.exit()把自己杀掉了。

现在Skynet已经启动了watchdog服务,监听着8888端口,等待客户端的链接。

下面是watchdog服务的skynet_start()开始函数:

认识skynet(3)--例子代码分析_第2张图片
watchdog

skynet.dispatch()这个服务的回调函数,通过SOCKET[]来调用函数,这些函数有:

SOCKET.open()打开agent服务并启动,使用gate来管理socket。SOCKET.close()关闭agent服务。

SOCKET.error()打印错误信息。

SOCKET.data()有数据到来。


下面就来看看agent服务的代码:

认识skynet(3)--例子代码分析_第3张图片
agent服务

前面watchdog调用SOCKET.open()的时候就调用了这里的CMD.start(),在客户端输出了”Welcome to skynet”。

Agent服务的核心就是注册了协议,并根据协议把数据发送给simpledb服务去处理:

认识skynet(3)--例子代码分析_第4张图片
Agent注册协议

协议的详细部分看lualib/skynet.lua。

最后我们看看simpledb服务:

认识skynet(3)--例子代码分析_第5张图片
simpledb服务

simpledb服务只是很简单的处理了SET和GET。


以上只是大概浏览了一遍Skynet附带的例子,了解了一些Skynet提供给lua使用的接口,其他接口可以查看skynet.lua代码。

你可能感兴趣的:(认识skynet(3)--例子代码分析)