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 :0000000d example/inject_simpledb.lua
inject ok!

使用 rlwrap 强化 skynet 控制台

前面提到了skynet控制台不能使用上下键回溯历史命令,退格键也不能使用等,为了弥补这个不足。能够使用 rlwrap
这里以 centos做说明。 rlwrap依赖 readline,系统必须装有 readline ,在现有非常多linux系统,readline都可自己主动化安装:
yum -y install readline-devel

rlwrap则须要手动安装。这里附 rlwrap下载地址。点这里。安装 rlwrap非常easy。例如以下:

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 相当于回车键
參考:
[1] DebugConsole  云风
[2] skynet 控制台管理使用技巧 没有开花的树

skynet 控制台管理使用技巧的更多相关文章

  1. 谈谈如何用eoLinker管理各类API接口及分享API接口管理小技巧教程

    在前后端分离的开发模式下,前后端往往需要接口文档来进行交互.我的上一篇随笔中已经写到用传统的文档写接口时,由于需求经常变动,接口文档也会随之变动.一开始,某接口信息已经写入文档,但后期因为需求变动,发 ...

  2. rocketmq-console控制台管理界面配置

    Rocketmq可视化管理控制台配置 前提: RocketMQ有一个对其扩展的开源项目incubator-rocketmq-externals,这个项目中有一个子模块叫“rocketmq-consol ...

  3. mysql控制台的一些技巧,显示,输入换行,语法正则等

    注释: 以/**注释内容**/ mysql> /**列出所有的数据库**/ show databases; +--------------------+ | Database | +------ ...

  4. golang 的glide包管理使用技巧教程

    安装glide ➜ wemall git:(master) ✗ go get github.com/Masterminds/glide ➜ wemall git:(master) ✗ go insta ...

  5. 控制台管理apk

    http://www.cnblogs.com/mythou/archive/2013/06/11/3132249.html pm命令的具体用法如下: pm 命令是Android里面packageMan ...

  6. 转:云风skynet服务端框架研究

    转:  http://forthxu.com/blog/skynet.html skynet是云风编写的服务端底层管理框架,底层由C编写,配套lua作为脚本使用,可换python等其他脚本语言.sky ...

  7. 内存管理 & 内存优化技巧 浅析

    内存管理 浅析 下列行为都会增加一个app的内存占用: 1.创建一个OC对象: 2.定义一个变量: 3.调用一个函数或者方法. 如果app占用内存过大,系统可能会强制关闭app,造成闪退现象,影响用户 ...

  8. VS Code开发技巧集锦

    2016 年 9 月 23-24 日,由 CSDN 和创新工场联合主办的“MDCC 2016 移动开发者大会? 中国”(Mobile Developer Conference China)将在北京? ...

  9. VS Code开发技巧集锦【转】

    转自:http://blog.csdn.net/tiantangyouzui/article/details/52163175 入门 自定义 扩展 文件/文件夹管理 编辑技巧 智能感应功能 代码片段 ...

随机推荐

  1. hihocoder offer收割编程练习赛13 D 骑士游历

    思路: 矩阵快速幂. 实现: #include <iostream> #include <cstdio> #include <vector> using names ...

  2. reduce的特殊用法

    //计算数组中每个元素出现的次数var arr = ["apple","orange","apple","orange" ...

  3. git分支拉取

    假设你已经配置好了各种SSH Key之类并熟悉基本的git创建分支.提交分支命令.比如共有2个分支,自己在一台未配置origin电脑上想要拉取某个分支(dev)到本地.步骤如下:1.新建git项目 与 ...

  4. DB2 系统命令与配置参数大全

    主要包括4个部分,分别为: DB2 系统命令 DB2 数据库管理器配置参数 DB2 数据库系统配置参数 DB2 管理服务器(DAS)配置参数DB2 系统命令 dasauto - 自动启动 DB2 管理 ...

  5. canvas一周一练 -- canvas绘制奥运五环(1)

    运行效果: <!DOCTYPE html> <html> <head> </head> <body> <canvas id=" ...

  6. vt100控制符

    vt100控制符是比较古老的字符,基本上的终端都能支持 今天突然来了兴致玩一玩儿 颜色配置 下面是我写的各种背景和字体颜色的搭配演示,挑选一种你喜欢的 echo -en "[背景\字体] & ...

  7. CAD删除组(网页版)

    主要用到函数说明: _DMxDrawX::DeleteGroup 根据组名,删除组.详细说明如下: 参数 说明 BSTR pszName 组名 js代码实现如下: 1 2 3 4 5 6 7 8 9 ...

  8. Vue-prop

    HTML 中的特性名是大小写不敏感的,所以浏览器会把所有大写字符解释为小写字符.这意味着当你使用 DOM 中的模板时,camelCase (驼峰命名法) 的 prop 名需要使用其等价的 kebab- ...

  9. CMU Database Systems - Two-phase Locking

    首先锁是用来做互斥的,解决并发执行时的数据不一致问题 如图会导致,不可重复读 如果这里用lock就可以解决,数据库里面有个LockManager来作为master,负责锁的记录和授权 数据库里面的基本 ...

  10. 如何在MONO 3D寻找最短路路径

    前段时间有个客户说他们想在我们的3D的机房中找从A点到B点的最短路径,然而在2D中确实有很多成熟的寻路算法,其中A*是最为常见的,而这个Demo也是用的A*算法,以下计算的是从左上角到右下角的最短路径 ...