Smalldok's Tech Blog

穷则变、变则通、通则达


  • 首页

  • 分类

  • 关于

  • 标签

  • 归档

  • 公益 404

  • 搜索

6-消息确认 ACK

| 分类于 源码学习 , MPush , 源码分析 , Mpush Server , 接入服务 | 评论数: | 阅读次数:

接收到客户端的ACK响应

1
2
//ConnectionServer#init()
messageDispatcher.register(Command.ACK, () -> new AckHandler(mPushServer));

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
public final class AckHandler extends BaseMessageHandler<AckMessage> {
private final AckTaskQueue ackTaskQueue;
public AckHandler(MPushServer mPushServer) {
this.ackTaskQueue = mPushServer.getPushCenter().getAckTaskQueue();
}
@Override
public AckMessage decode(Packet packet, Connection connection) {
return new AckMessage(packet, connection);
}
@Override
public void handle(AckMessage message) {
AckTask task = ackTaskQueue.getAndRemove(message.getSessionId());
if (task == null) {//ack 超时了
Logs.PUSH.info("receive client ack, but task timeout message={}", message);
return;
}
task.onResponse();//成功收到客户的ACK响应
}
}



接入服务文章目录:

  • 1-心跳 HEARTBEAT
  • 2-握手 HANDSHAKE
  • 3-用户绑定-解绑 BIND-UNBIND
  • 4-快速连接 FAST_CONNECT
  • 5-客户端推送 PUSH
  • 6-消息确认 ACK
  • 7-HTTP代理 HTTP_PROXY
1…767778…100
smalldok

smalldok

JAVA服务端架构,目前方向是微服务落地、基础设施、中间件、DevOps

100 日志
27 分类
17 标签
Links
  • sofa-bolt
  • sofa-rpc
  • dubbo
  • sofa-tracer
  • sofa-boot
  • Sentinel
  • COLA
  • nacos
  • xxl-job
  • apollo
  • sharding-sphere
  • fescar
  • ByteTCC
  • tcc-transaction
  • rocketmq
  • canal
  • arthas
  • jvm-sandbox
  • sofa-lookout
  • disruptor
  • mpush
© 2007 – 2019 smalldok
由 Hexo 强力驱动 v3.8.0
|
主题 – NexT.Mist v6.7.0