Skynet启动examples/config脚本,通过start=”main”开启了第一个Skynet的服务main.lua,这个文件也在examples中,我们看看这个文件写的什么:
第一行先引用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.dispatch()这个服务的回调函数,通过SOCKET[]来调用函数,这些函数有:
SOCKET.open()打开agent服务并启动,使用gate来管理socket。SOCKET.close()关闭agent服务。
SOCKET.error()打印错误信息。
SOCKET.data()有数据到来。
下面就来看看agent服务的代码:
前面watchdog调用SOCKET.open()的时候就调用了这里的CMD.start(),在客户端输出了”Welcome to skynet”。
Agent服务的核心就是注册了协议,并根据协议把数据发送给simpledb服务去处理:
协议的详细部分看lualib/skynet.lua。
最后我们看看simpledb服务:
simpledb服务只是很简单的处理了SET和GET。
以上只是大概浏览了一遍Skynet附带的例子,了解了一些Skynet提供给lua使用的接口,其他接口可以查看skynet.lua代码。