zoukankan      html  css  js  c++  java
  • skynet 控制台管理使用技巧

    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 控制台管理使用技巧 没有开花的树

  • 相关阅读:
    matlab绘图的坐标轴数字、范围、间隔控制
    机器学习降维算法一:PCA(主成分分析算法)
    信息检索X科普一:查准与召回(Precision & Recall),F1 Measure
    matlab 绘图字体大小控制
    机器学习降维算法二:LDA(Linear Discriminant Analysis)
    25款.NET开发工具
    CA0503:无法显示额外的代码分析警告或错误
    ReportViewer实例教程
    Rational Rose2003 安装错误之error 1920.service NUTCRACKERservice
    读取SqlServer表名及结构
  • 原文地址:https://www.cnblogs.com/brucemengbm/p/7136640.html
Copyright © 2011-2022 走看看