ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

基于nchan 开发消息服务的一些核心知识点

2022-06-05 17:00:58  阅读:163  来源: 互联网

标签:知识点 基于 nchan 处理 redis 消息 channel


以前简单说明下如何集成,在此说明下集成核心的指令,可以加速我们的集成

参考集成模式

此图以前简单介绍过

 

 


核心: 基于redis 以及一些消息管理api,我们利用nchan 提供的auth 以及消息转发能力,对于消息进行处理,对于消息做一些扩展

几个核心指令

  • 认证&安全
    因为部分处理属于长连接,连接是在首次建立处理的,具有一些特殊性,与短链接是不一样的
    核心指令
 
nchan_authorize_request

当然我们也可以基于openresety 做一些扩展基于access_by_lua*
同时如果有些订阅有特殊场景的,可以直接基于nginx 的指令处理(比如ip 处理,internel,以及监听本地端口)
而且有些场景我们存在对于通道权限的回收(比如权限改变)解决方法:对于通道id 与订阅是一样的可以删除通道(直接基于api delete 操作)
对于复杂双工通道的,因为删除通道会卸载相关的连接,所以效果也是类似的

  • 状态处理
    核心是对于建立连接的客户端状态统计,包含了订阅以及取消订阅
 
nchan_subscribe_request  
nchan_unsubscribe_request 

注意使用以上的时候注意配置proxy_ignore_client_abort on; 否则消息状态可能会不正常(449 状态码)

  • 消息转发
    基于消息转发hook 我们可以扩展消息,当然也可以进行发送数据的校验以及权限处理(以及的后端服务以及配置)
 
nchan_publisher_upstream_request
  • 历史消息处理
    主要是新建立连接的消息订阅者对于消息的处理,这个还是推荐首次基于拉模式或者历史(通过短链接api),对于特殊场景的消息处理
    可能需要使用直接拉去历史消息的处理
 
nchan_subscriber_first_message
  • 消息存储
    对于实际使用推荐的肯定是基于redis的(当然单机基于内存也是可以的),如果已经有redis cluster 这个是比较推荐的,可以提高系统的可靠性
    对于redis 的安全同时也支持配置用户密码
 
nchan_redis_username 
nchan_redis_password 
nchan_redis_server
  • 消息订阅状态的监控
    nchan 包含了内置的以及一些其他扩展点,基于内置的meta 特殊通道组,我们可以获取定于以及发送信息
 
location ~ /channel_events/(.+) {
  #channel events subscriber location
  nchan_subscriber;
  nchan_channel_group meta; #"meta" is a SPECIAL channel group
  nchan_channel_id $1;
}

以及类似nginx stauts 的 nchan_stub_status 指令(基于可以做一些监控)

一些限制

默认每个连接可以创建的通道为255(属于设计上的考虑),如果需要突破255限制就需要使用双工通道了
具体参考src/util/nchan_channel_id.c
参考配置

 
nchan_channel_id "$1" "$2" "common_channel";

同时对于以上处理的权限变动创建也会存在问题的(删除通道,可能会对于其他使用的有影响)

说明

以上是一些使用总结,还是推荐研究下源码

参考资料

https://nchan.io/#getting-started
https://www.cnblogs.com/rongfengliang/p/16343179.html

标签:知识点,基于,nchan,处理,redis,消息,channel
来源: https://www.cnblogs.com/rongfengliang/p/16344341.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有