Noark入门之协议映射

Stella981
• 阅读 438

0x00消息控制器

消息控制器,主要作用就是为每个模块提供消息处理的入口.

这里的消息不仅仅是协议,还有内部指令,事件等等逻辑入口,这也是为了响应线程模型作出的一种支撑,只要入口在此消息控制器内,那必然走期望的线程调度。

@Controller用于标识一个类为当前模块的消息控制器入口.

@Controller(threadGroup = ExecThreadGroup.PlayerThreadGroup)
public class MailController {
}

参数threadGroup标识此入口是按玩家线程组划分的,每个玩家之前的逻辑互不影响.

@Controller(threadGroup = ExecThreadGroup.ModuleThreadGroup)
public class LoginController {
}

这个就是以模块为单位划分的,就是说这个模块的所有逻辑都是以串型的方式在执行.

0x01协议映射

@PacketMapping注解用来标识一个封包映射到一个处理方法

@PacketMapping(opcode = 1001, state = State.CONNECTED)
public void loginGame(Session session, LoginGameReq request) {
}

参数opcode表示协议编号 参数state表示当前状态才可以调用的执行

如果Session的状态在刚刚链接的情况下接受到1001协议才可以执行此方法

如果正常执行完一个逻辑则会有一行日志

2018-09-04 15:58:32.868 [business-1] INFO AsyncTask.java:59 - handle protocal(opcode=1001),delay=0.15324 ms,exe=3.608036 ms

PacketMapping还有个参数

printLog 是否需要打印协议相关的日志,默认值是true , 如果不想要日志输入 则可以设计为false

比如心跳协议,则不需要输出日志,状态也是不管他登录未登录...

@PacketMapping(opcode = MsgType.KeepalivedReq_VALUE, printLog = false, state = State.ALL)
public void keepalived(Session session, KeepalivedReq request) {
    session.send(MsgType.KeepalivedAck_VALUE, KeepalivedAck.newBuilder().setNow(System.currentTimeMillis()).build());
}

是不是找到了当年SpringMvc的感觉了,那就对了... 熟悉的才是最美好的回忆

点赞
收藏
评论区
推荐文章
blmius blmius
2年前
MySQL:[Err] 1292 - Incorrect datetime value: ‘0000-00-00 00:00:00‘ for column ‘CREATE_TIME‘ at row 1
文章目录问题用navicat导入数据时,报错:原因这是因为当前的MySQL不支持datetime为0的情况。解决修改sql\mode:sql\mode:SQLMode定义了MySQL应支持的SQL语法、数据校验等,这样可以更容易地在不同的环境中使用MySQL。全局s
Jacquelyn38 Jacquelyn38
2年前
2020年前端实用代码段,为你的工作保驾护航
有空的时候,自己总结了几个代码段,在开发中也经常使用,谢谢。1、使用解构获取json数据let jsonData  id: 1,status: "OK",data: 'a', 'b';let  id, status, data: number   jsonData;console.log(id, status, number )
皕杰报表之UUID
​在我们用皕杰报表工具设计填报报表时,如何在新增行里自动增加id呢?能新增整数排序id吗?目前可以在新增行里自动增加id,但只能用uuid函数增加UUID编码,不能新增整数排序id。uuid函数说明:获取一个UUID,可以在填报表中用来创建数据ID语法:uuid()或uuid(sep)参数说明:sep布尔值,生成的uuid中是否包含分隔符'',缺省为
Stella981 Stella981
2年前
Python之time模块的时间戳、时间字符串格式化与转换
Python处理时间和时间戳的内置模块就有time,和datetime两个,本文先说time模块。关于时间戳的几个概念时间戳,根据1970年1月1日00:00:00开始按秒计算的偏移量。时间元组(struct_time),包含9个元素。 time.struct_time(tm_y
Stella981 Stella981
2年前
OFBiz 快速入门——续二
OFBiz快速入门——续二2011年03月17日星期四00:03OFBiz 快速入门2.5 创建一个文件,取名为(controller.xml),被OFBiz webapp控制器使用的。在没有额外增加功能时,这个文件内容非常的小与简单,如下:<?xml version"1.0" encoding"UTF8"?<siteco
Stella981 Stella981
2年前
Django中Admin中的一些参数配置
设置在列表中显示的字段,id为django模型默认的主键list_display('id','name','sex','profession','email','qq','phone','status','create_time')设置在列表可编辑字段list_editable
Wesley13 Wesley13
2年前
thinkphp url模式
入口文件是应用的单一入口,对应用的所有请求都定向到应用入口文件,系统会从URL参数中解析当前请求的模块、控制器和操作:1.http://serverName/index.php/模块/控制器/操作这是3.2版本的标准URL格式。可以通过设置模块绑定或者域名部署等方式简化URL地址中的模块及控制器名称。URL大小写
Stella981 Stella981
2年前
Noark入门之异步事件
引入异步事件主要是为了各模块的解耦,每当完成一个动作时,向系统发布一个事件,由关心的模块自己监听处理,可选择同步处理,异步处理,延迟处理。何时发布事件,当其他模块关心此动作时<br比如获得道具时,任务系统模块要判定完成进度,BI模块需要上报等等都可以监听此事件,已达模块解耦0x00事件源一个实现xyz.noark.core.event
Wesley13 Wesley13
2年前
MySQL部分从库上面因为大量的临时表tmp_table造成慢查询
背景描述Time:20190124T00:08:14.70572408:00User@Host:@Id:Schema:sentrymetaLast_errno:0Killed:0Query_time:0.315758Lock_
Python进阶者 Python进阶者
3个月前
Excel中这日期老是出来00:00:00,怎么用Pandas把这个去除
大家好,我是皮皮。一、前言前几天在Python白银交流群【上海新年人】问了一个Pandas数据筛选的问题。问题如下:这日期老是出来00:00:00,怎么把这个去除。二、实现过程后来【论草莓如何成为冻干莓】给了一个思路和代码如下:pd.toexcel之前把这