实时在线设备统计应该保存在SQL,Redis Set还是Redis Sorted Set? -问答-阿里云开发者社区-阿里云

开发者社区> 问答> 正文

实时在线设备统计应该保存在SQL,Redis Set还是Redis Sorted Set?

2016-03-09 10:16:23 3228 1

之前我用Redis保存实时采集的数据,现在需要额外的数据结构记录实时在线设备。

传统MySQL数据库,
onConnectionMade(),更新SQL数据库;
onConnectionLost(),更新SQL数据库;

Redis Set,
onConnectionMode(),在online(set)中增加对应设备SNR;
onConnectionLost(),在online(set)中删除对应设备SNR;

Redis Sorted Set,
onConnectionMode(),在online(set)中增加对应设备SNR;
onConnectionLost(),在online(set)中删除对应设备SNR;

我纠结以下问题:

1.采用Sorted Set固然好处比较多,但却是Redis最复杂的数据类型,不知道会占用多少资源?10K设备,每个SNR大约16字节。

2.如果采用Set,如果采用分页显示设备清单,如果10K设备,即使采用JSON,是否一次返回太多数据?好像缺乏range和通配符之类的操作。

3.此类操作是否SQL更有优势?毕竟长连接情况下,更新频率不高。

4.如果重启服务器,那么这个数据库表需要清表,Redis下操作简单,但是SQL是否会锁表?

取消 提交回答
全部回答(1)
  • 爵霸
    2019-07-17 18:55:28

    hello, 最近正在做这方面的工作,就是统计websocket的在线连接数量,一开始也是统计在redis的,后来采用日志对接storm实时处理去做了。因为一旦在多进程多机器的集群模式下,不管是数据库还是redis缓存,复杂度就很高了,某一个进程崩溃了,怎么清空他对应的连接呢?用最小的成本去解决这个问题就是在连接创建跟关闭的时候在日志里面打印出自己的连接数。
    storm平台实时收集日志就可以计算出总的在线连接了,并且可以动态扩展伸缩进程和集群数量,这是数据库跟缓存不好实现的地方。

    0 0
相关问答

20

回答

【大咖问答】对话PostgreSQL 中国社区发起人之一,阿里云数据库高级专家 德哥

阿里ACE 彭飞 2019-07-10 09:36:10 1226119浏览量 回答数 20

145

回答

【新手入门】云服务器linux使用手册

fanyue88888 2012-11-26 17:14:18 159461浏览量 回答数 145

8

回答

OceanBase 使用动画(持续更新)

mq4096 2019-02-20 17:16:36 340541浏览量 回答数 8

38

回答

[@饭娱咖啡][¥20]对于慢sql有没有什么比较实用的诊断和处理方法?

江小白太白 2018-10-30 18:47:38 143911浏览量 回答数 38

22

回答

爬虫数据管理【问答合集】

我是管理员 2018-08-10 16:37:41 148558浏览量 回答数 22

39

回答

安全组详解,新手必看教程

我的中国 2017-11-30 15:23:46 262941浏览量 回答数 39

21

回答

请教一下数据量有100万条左右要什么配置?

易网网络 2013-03-27 15:18:02 193545浏览量 回答数 21

251

回答

阿里云LNAMP(Linux + Nginx + Apache + MySQL + PHP)环境一键安装脚本

云代维 2014-02-14 15:26:06 309418浏览量 回答数 251

24

回答

【精品问答】python技术1000问(1)

问问小秘 2019-11-15 13:25:00 483485浏览量 回答数 24

2

回答

区域选择帮助

fanyue88888 2012-12-07 15:54:30 205452浏览量 回答数 2
+关注
2
文章
9426
问答
问答排行榜
最热
最新
相关电子书
更多
JS零基础入门教程(上册)
立即下载
性能优化方法论
立即下载
手把手学习日志服务SLS,云启实验室实战指南
立即下载