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

作者: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这几个重要的方法。顺便看了一下配置文件。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 201,552评论 5 474
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 84,666评论 2 377
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 148,519评论 0 334
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,180评论 1 272
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,205评论 5 363
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,344评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,781评论 3 393
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,449评论 0 256
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,635评论 1 295
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,467评论 2 317
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,515评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,217评论 3 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,775评论 3 303
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,851评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,084评论 1 258
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,637评论 2 348
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,204评论 2 341

推荐阅读更多精彩内容