Redis实现微博后台业务逻辑系列(七)

简介:

微博点赞功能的实现:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
import  redis
 
class  LikeMessage( object ):
     """实现微博点赞功能"""
     def  __init__( self , msg_id, client):
         self .msg_id  =  msg_id
         self .client  =  client
         self .key  =  "weibo::message::"  +  str (msg_id)  +  "::like"
         
     def  like( self , user_id):
         """对该微博点赞"""
         self .client.sadd( self .key, user_id)
         
     def  is_liking( self , user_id):
         """检查用户是否赞了该微博"""
         return  self .client.sismember( self .key, user_id)
         
     def  undo( self , user_id):
         """取消点赞"""
         self .client.srem( self .key, user_id)
         
     def  count( self ):
         """获取该微博点赞人数"""
         return  self .client.scard( self .key)
         
     def  get_all_liking_user( self ):
         """返回赞了该微博的所有用户"""
         if  not  self .client.exists( self .key):
             return  False
         else :
             return  self .client.smembers( self .key)
             
             
if  __name__  = =  "__main__" :
     redis_client  =  redis.StrictRedis()
     vote  =  LikeMessage( 65535 , redis_client)
     vote.like( 10010 )
     vote.like( 10086 )
     vote.like( 10000 )
     print (vote.count())
     print (vote.is_liking( 10086 ))
     vote.undo( 10086 )
     print (vote.get_all_liking_user())

    在这里我们使用无序集合键来保存对微博的点赞信息,我们在之前的文章已经用无序集合键实现了保存微博用户之间的关系,无序集合键还可以实现例如书籍的标签信息,个人标签等。只要是不在乎数据存储的顺序,并且数据必须是唯一的,都可以用无序集合键来实现功能。对于每条微博,redis都会创建一个"weibo::message::<id>::like"的无序集合键来存储对该微博点赞的用户。

本文转自戴柏阳的博客博客51CTO博客,原文链接http://blog.51cto.com/daibaiyang119/1963055如需转载请自行联系原作者


daibaiyang119

相关文章
|
NoSQL Java Redis
springboot搭建后台框架 (二)整合Redis
springboot搭建后台框架 (二)整合Redis
188 0
|
NoSQL Linux Redis
linux下后台启动redis
linux下后台启动redis
510 0
|
NoSQL Linux Redis
Linux系统中安装redis+redis后台启动+常见相关配置
Linux系统中安装redis+redis后台启动+常见相关配置
|
12月前
|
存储 NoSQL 数据库
Redis 逻辑数据库与集群模式详解
Redis 是高性能内存键值数据库,广泛用于缓存与实时数据处理。本文深入解析 Redis 逻辑数据库与集群模式:逻辑数据库提供16个独立存储空间,适合小规模隔离;集群模式通过分布式架构支持高并发和大数据量,但仅支持 database 0。文章对比两者特性,讲解配置与实践注意事项,并探讨持久化及性能优化策略,助你根据需求选择最佳方案。
588 5
|
NoSQL Linux 测试技术
redis的安装步骤及前台,后台redis服务启动
这篇文章介绍了Redis的安装步骤,包括在Linux系统中下载、传输、解压、编译、安装Redis,以及Redis服务的前台和后台启动方法。
redis的安装步骤及前台,后台redis服务启动
|
JavaScript NoSQL Java
CC-ADMIN后台简介一个基于 Spring Boot 2.1.3 、SpringBootMybatis plus、JWT、Shiro、Redis、Vue quasar 的前后端分离的后台管理系统
CC-ADMIN后台简介一个基于 Spring Boot 2.1.3 、SpringBootMybatis plus、JWT、Shiro、Redis、Vue quasar 的前后端分离的后台管理系统
543 0
|
NoSQL Redis 数据库
Redis 常见面试问题 Redis持久化aof后台重写和写时复制
今天有个群里网友问,redis面试被问到aof 后台重写 写时复制,我尝试回答一下
781 104
|
存储 缓存 NoSQL
Redis性能优化问题之优化 Redis fork 耗时严重的问题,如何解决
Redis性能优化问题之优化 Redis fork 耗时严重的问题,如何解决
|
缓存 NoSQL Redis
Redis性能优化问题之当Redis内存达到maxmemory后,淘汰数据的逻辑是怎样的
Redis性能优化问题之当Redis内存达到maxmemory后,淘汰数据的逻辑是怎样的
|
存储 NoSQL 数据处理
Redis Lua脚本:赋予Redis更强大的逻辑与功能
Redis Lua脚本:赋予Redis更强大的逻辑与功能
366 0