游戏开发

skynet教程(1)--服务的编写

2017-09-01  本文已影响1228人  天一阁图书管理员

作者:shihuaping0918@163.com,转载请注明作者

自从skynet源码分析系列文章发布以后,陆续收到不少的反馈,说需要一个step by step的教程,身边的朋友也要求出个教程。�于是就写了这个教程。

每个教程都是从hello world开始的,所以先写一个echo服务作为hello world版本。echo服务先放在skynet/example这个目录下,因为配置相关的东西还没有讲到。环境准备需要:

1.inux或者mac osx。
2.编绎好的skynet。
3.一个可以编写lua的编辑器。可参考的是eclipse ldt/sublime text

skynet的WIKI是需要熟读的,wiki的篇幅很大,但是不读WIKI对于开发很不利。
https://github.com/cloudwu/skynet/wiki

skynet刚开始是单进程多线程的,它是由一个一个的服务组成的。在skynet上做开发,实际上就是在写服务。服务与服务之间通过消息队列进行通信。这一篇讲的就是服务该怎么写。

一、首先引入框架
local skynet = require "skynet"

然后要准备一个回调函数,每个服务都有一个回调函数,这个回调函数是被skynet框架调用的,当有消息投递到服务上时,skynet框架就会调用服务的回调函数对消息进行处理。这个回调函数是skynet.dispatch。

最后要使用skynet.start把服务启动起来。

skyet/example/echo.lua

local skynet = require "skynet"
require "skynet.manager"


local command = {}

function command.HELLO(what)
    return "i am echo server, get this:" .. what
end

function dispatcher() 
    skynet.dispatch("lua", function(session, address, cmd, ...)
        cmd = cmd:upper()
        if cmd == "HELLO" then
            local f = command[cmd]
            assert(f)
            skynet.ret(skynet.pack(f(...)))
        end
    end)
    skynet.register("echo")
end

skynet.start(dispatcher)

这里需要解释一下,session,address,cmd是什么,...是代表可变参数,这个就不解释了。session在代码分析的时候讲过,它是一个自增的数字,而且溢出了又从1开始。实际上可以理解为请求序号,请求方收到回应的时候,用session这个数字就能识别出来回应包是对应的哪一个发出去的请求,这个请求是请求方发出去的。在异步请求的时候经常需要这个东西。

address是skynet中服务的地址,这个地址在运行时是唯一的。在上面的代码中就是代表echo服务自已的地址。它实际上也是一个数字。

cmd就是命令字了,这个就不多解释了。下面还会讲到。

skynet.register("echo")这一句就是给服务起个名字,这个在源码分析的时候也讲过了,这个名字是不可以重复的。

二、写完上面的代码是不是就大功告成了呢,实际上并没有。要测这个服务,我们还需要另写一个服务,可能有的人心中默默地已经在念三字经了。在没有搭建服务端,纯在skynet环境中运行测试,目前只能这样了。

skynet/example/test_echo.lua

local skynet = require "skynet"

skynet.start(function() 
    local echo = skynet.newservice("echo")
    print(skynet.call(echo, "lua", "HELLO", "world"))
end);

注意不要直接使用skynet去启动test_echo.lua脚本,一定会报错的。不管我这里怎么讲,我相信一定会有人要去试一试的。

skynet.newservice是启动echo服务。

skynet.call是调用服务,其中参数echo就是上面dispatch对应的address,参数"lua"就是dispatch中的lua,"HELLO"就是上面对应的cmd。参数"world"就是...里面的内容了。call是阻塞式调用。

到了这一步是不是就可以了?不不不,还有第三步,不过第三步很简单。

三、修改配置文件example/config
在源码分析中分析过了,skynet一定需要一个配置文件,在里面配置cpath/thread之类的信息。先备份一下example/config文件。然后再个性example/config文件,把start那一行

start = "main"  -- main script

改为

start = "test_echo" -- main script

保存,保存,保存,重要的事情说三遍,一定要保存。

这个start就是skynet要去运行的lua入口脚本

四、好了,现在运行
./skynet ./example/config,恭喜你,成功的话会出现

i am echo server, get this:world
[:01000002] KILL self

到此为止,服务的编写例子就完成了。这一篇里我们学习了skynet.start、skynet.dispatch、skynet.register、skynet.call、skynet.newservice这几个重要的方法。顺便看了一下配置文件。

上一篇下一篇

猜你喜欢

热点阅读