skynet 自带了一个控制台服务,可以很方便获取和调试 skynet 运行数据,而且可以热更新代码,所以,弄明白skynet控制台管理可以让你更好地使用skynet,甚至改进这个控制台服务,以满足不同业务需求。
这个服务默认不会启动,需要你手动启动它,如下:
skynet.newservice("debug_console", 8000)
设计原因,调试控制台只监听本地地址 127.0.0.1 ,如果需要远程使用,需要先登录到本机,然后再连接。
使用时,通过 telnet 或 nc 登录调试控制台,启动后显示:
$ nc 127.0.0.1 8000
Welcome to skynet console
表示连接成功。
注:skynet控制台不能使用上下键回溯历史命令,退格键也不能使用(改用删除键)等等,这是由于 skynet 使用了自己的 IO 库,很难接入libreadline (不能在 readline 的 hook 中 yield)。如果希望在控制台中使用 readline 的 history 等特性,可以自己使用 rlwrap 。
这时,你可以输入调试指令,输入 help 可以列出目前支持的所有指令。(不同版本结果不同)
$ nc 127.0.0.1 8000
Welcome to skynet console
help
clearcache clear lua code cache
cmem Show C memory info
debug debug address : debug a lua service
exit exit address : kill a lua service
gc gc : force every lua service do garbage collect
help This help message
info Info address : get service infomation
inject inject address luascript.lua
kill kill address : kill service
list List all the service
logoff logoff address
logon logon address
mem mem : show memory status
service List unique service
signal signal address sig
snax lanuch a new snax service
start lanuch a new lua service
stat Dump all stats
task task address : show service task detail
|
命令的一般格式是 命令 地址 ,有些命令不带地址,会针对所有的服务。当输入地址时,可以使用 :01000001 这样的格式指代一个服务地址:由冒号开头的 8 位 16 进制数字,也可以省略前面两个数字的 harbor id 以及接下来的连续 0 ,比如 :01000001 可以简写为 1 。所有活动的服务可以输入 list 列出。
常用的通用指令:
list 列出所有服务,以及服务的启动参数。
gc 对所有 lua 服务执行gc,并列出gc后所有服务的内存情况。
mem 列出所有 lua 服务的内存占用情况。(注:只获取 lua 服务的 lua vm 内存占用情况,如果需要 C 模块中内存使用情况,使用cmem。)
stat 列出所有 lua 服务的消息队列长度,以及被挂起的请求(协程)数量。
service 列出所有的唯一 lua 服务。
注意,由于这些指令是逐个向每个服务发送消息并等待回应,所以当某个 lua 服务过载时,可能需要等待很长时间才有返回。
针对单个 lua 服务的指令:
exit address 退出指定 lua 服务
kill address 强制中止指定 lua 服务。
info address 让指定 lua 服务输出自己的内部信息(数据通过回调服务内 skynet.info_func 生成)
signal address sig 向服务发送一个信号,sig 默认为 0 。当一个服务陷入死循环时,默认信号会打断正在执行的 lua 字节码,并抛出 error 显示调用栈。这是针对 endless loop 的 log 的有效调试方法。(注:这里的信号并非系统信号。)
task address 显示一个服务中所有被挂起的请求的调用栈。
debug address 针对一个 lua 服务启动内置的单步调试器。http://blog.codingnow.com/2015/02/skynet_debugger.html
logon/logoff address 记录一个服务所有的输入消息(source, type, session, data, size)到文件。(生成文件的路径地址取配置 logpath) 。
inject address script 将 script 对应的脚本插入到指定服务中运行(通常可用于热更新补丁)。
这里重点说下info address 和inject address script,这两个命令很重要。
获取服务内部数据 - info address
前面提到,这个命令让指定 lua 服务输出自己的内部信息,数据通过回调服务内 skynet.info_func 生成。
下面以 example/simpledb.lua做说明,这是个典型的skynet服务。
local skynet = require "skynet"
require "skynet.manager" -- import skynet.register
local db = {}
local command = {}
function command.GET(key)
return db[key]
end
function command.SET(key, value)
local last = db[key]
db[key] = value
return last
end
-- 新增的代码 -- start
skynet.info_func(function() return "hello mycwq!" end)
-- 新增的代码 -- end
skynet.start(function()
skynet.dispatch("lua", function(session, address, cmd, ...)
local f = command[string.upper(cmd)]
if f then
skynet.ret(skynet.pack(f(...)))
else
error(string.format("Unknown command %s", tostring(cmd)))
end
end)
skynet.register "SIMPLEDB"
end)
启动example例子,连接控制台,
$ nc 127.0.0.1 8000
Welcome to skynet console
list
:00000004 snlua cmaster
:00000005 snlua cslave
:00000007 snlua datacenterd
:00000008 snlua service_mgr
:0000000a snlua protoloader
:0000000b snlua console
:0000000c snlua debug_console 8000
:0000000d snlua simpledb
:0000000e snlua watchdog
:0000000f snlua gate
OK
info:0000000d
hello mycwq!
|
代码热更新 - inject address script
前面提到,这个命令将 script 对应的脚本插入到指定服务中运行
下面写个简单的inject例子,保存为 example/inject_simpledb.lua
if not _P then
print "inject error!!"
return
end
local command = _P.lua.command
command.TEST = function() return "TEST" end
print "inject ok!"
启动example例子,连接控制台,
$ nc 127.0.0.1 8000
Welcome to skynet console
list
:00000004 snlua cmaster
:00000005 snlua cslave
:00000007 snlua datacenterd
:00000008 snlua service_mgr
:0000000a snlua protoloader
:0000000b snlua console
:0000000c snlua debug_console 8000
:0000000d snlua simpledb
:0000000e snlua watchdog
:0000000f snlua gate
OK
inject:0000000dexample/inject_simpledb.lua
inject ok!
|
使用rlwrap 强化 skynet 控制台
前面提到了skynet控制台不能使用上下键回溯历史命令,退格键也不能使用等,为了弥补这个不足,可以使用rlwrap
这里以 centos做说明, rlwrap依赖 readline,系统必须装有 readline ,在现有很多linux系统,readline都可自动化安装:
yum -y install readline-devel
rlwrap则需要手动安装,这里附rlwrap下载地址,点这里。
安装 rlwrap很简单,如下:
tar -zxf rlwrap-0.37.tar.gz
cd rlwrap-0.37
./configure
make && make install
以后,skynet控制台的连接方式改成这样,就可以回溯命令了。
$ rlwrap nc 127.0.0.1 8000
Welcome to skynet console
list
:01000004 snlua cmaster
:01000005 snlua cslave
:01000007 snlua datacenterd
:01000008 snlua service_mgr
:0100000a snlua protoloader
:0100000b snlua console
:0100000c snlua debug_console 8000
:0100000d snlua simpledb
:0100000e snlua watchdog
:0100000f snlua gate
OK
|
最后,这里列举 rlwrap常用的快捷键:
Ctrl+L 清屏,实际是将当前行置顶
Ctrl+P 上一条命令
Ctrl+N 下一条命令
Ctrl+U 从光标处删除到行首
Ctrl+W 向前删除一个单词
Ctrl+B 光标向前移动一个位置
Ctrl+T 光标处字符与前一个字符交换位置
Ctrl+Z 后台运行,使用fg调出
Ctrl+H 相当于删除键
Ctrl+J 相当于回车键
Ctrl+O 相当于回车键
Ctrl+M 相当于回车键
参考:
分享到:
相关推荐
本文将深入探讨标题提及的“Websocket笔记三:egret + skynet使用protobuf”这一主题,结合描述中的源代码,我们将围绕Egret、Skynet以及Protocol Buffers(protobuf)这三个关键词展开讨论。 首先,Egret是一个...
为了更深入地学习和使用Skynet,你需要熟悉它的服务管理机制,理解如何编写和注册服务,以及如何使用Lua进行网络编程。同时,Skynet的源代码清晰易读,非常适合学习网络编程和并发控制。 总之,`skynet-vs2013`提供...
Skynet使用轻量级的协程模型来处理并发,每个服务运行在一个独立的线程上,通过消息传递进行通信。断点调试可以帮助我们追踪服务间的交互,理解逻辑流程,以及定位可能的错误。 总之,通过在VSCode中配置正确的调试...
由于Skynet的开发重点是Lua脚本,文档应该会详细指导如何使用Lua来编写服务,并且可能会提供一些基本的Lua脚本编写和调试技巧。 总结,Skynet框架之菜鸟手册是一本适合初学者学习和入门的指南,涵盖了Skynet框架的...
它涉及到服务休眠、线程的使用、执行权限的管理、执行权的让出以及定时器的管理等。定时器在Skynet中使用非常频繁,它允许服务在特定时间后执行或周期性执行任务。 服务间的通信是Skynet框架的灵魂。Skynet定义了...
《Skynet在Windows环境下使用VS2013的编译实践》 Skynet是一个轻量级、高性能的服务框架,主要用于构建分布式系统。它以其微服务架构、高效的网络通信能力和简单的编程模型深受开发者喜爱。在Windows操作系统中,...
尽管这个版本仅供学习,但在生产环境中使用 Skynet 时,建议使用官方发布的稳定版本,因为这些版本经过了更严格的测试,性能和稳定性更有保障。同时,要关注 Skynet 社区的更新,以便获取最新的功能和安全修复。 8...
Skynet使用协程来实现非阻塞I/O,使得服务可以在等待I/O操作完成的同时执行其他任务。在示例中,你会看到如何使用`skynet.coroutine`启动协程,以及如何在服务中处理事件,如接收客户端消息。 四、服务注册与发现 ...
- 使用版本管理工具(如 Git)来管理 Skynet 的源代码,便于版本控制和协作。 - 了解 Skynet 的服务模型,编写可扩展和模块化的服务代码。 - 利用 Skynet 的热更新功能,实现在不停服的情况下更新服务。 通过...
使用skynet_fly的好处: * 支持不停服更新。 * 一键生成skynet的配置文件和skynet_fly的配置文件以及配套shell脚本。 * 对匹配房间类游戏做了gate,ws_gate的基础设施封装以及pb,json协议的支持,开发游戏只需要实现...
3. **消息机制**:Skynet使用独特的消息队列机制,每个服务都有一个消息循环,负责处理接收到的消息。消息的发送和接收都是异步的,这保证了服务之间的低延迟通信。 4. **服务注册与发现**:Skynet提供了服务注册和...
Skynet使用Lua作为配置和脚本语言,允许开发者通过编写Lua脚本来定制服务的行为和配置。此外,Skynet的启动流程涉及到多线程的创建和管理,包括监视线程、定时器线程、网络线程和工作线程等,每个线程都具有特定的...
博主可能对各个部分进行了详细的讲解,包括代码逻辑、设计思路和使用技巧,这将帮助我们更好地理解和应用Skynet。 总的来说,通过这个项目源码,我们可以系统学习Skynet的基础知识,包括服务创建、消息处理、Socket...
《Skynet在Windows环境下与Visual Studio 2019的集成及应用》 Skynet,一个轻量级、高并发的分布式系统...在实际应用中,开发者应深入理解Skynet的架构原理,熟练掌握VS2019的使用技巧,以充分发挥这套工具集的优势。
- **玩家管理**:每个玩家作为一个服务实例,记录玩家的状态、属性和行为,通过RPC与其他服务交互。 - **世界状态**:维护游戏世界的静态和动态数据,如地形、怪物、NPC等,同时处理玩家对世界的互动。 - **战斗系统...
本文将深入探讨Skynet在Windows上使用Mingw编译版本的相关知识,帮助读者理解其工作原理和应用技巧。 首先,让我们了解什么是Mingw。Mingw是GNU Compiler Collection (GCC)在Windows平台上的移植,它提供了与Unix/...
Skynet使用Lua作为主要的编程语言,Lua语法简洁,易于学习,且与C++底层紧密集成,提供了高效的脚本执行性能。 总的来说,Skynet是一个强大的分布式服务器框架,它为游戏开发和其他实时应用提供了一种高效、灵活的...
Skynet使用轻量级的协程来实现并发,而不是传统的多线程。协程在单个线程中运行,避免了线程切换的开销,同时保持了多任务并行处理的能力。在VS2015中,可以利用C++11的std::coroutine库来实现类似的功能。 5. **...
5. **服务发现与管理**:Skynet内置了服务发现和管理机制,可以自动发现并管理网络中的服务,简化了服务间的交互和依赖管理。 6. **分布式能力**:Skynet可以轻松部署在多台机器上,形成分布式系统,支持负载均衡和...
Skynet的轻量级设计和高效的内存管理策略使其在处理高并发场景时表现出色。它使用了最小化内存分配和对象池等技术,降低了系统开销,提升了整体性能。 总之,Skynet的启动流程涉及了服务初始化、加载、调度、消息...