您的位置:首页 > 健康 > 养生 > 深圳市建设工程交易服务中心网站_装潢设计师_怎么让网站排名上去_精准网络营销推广

深圳市建设工程交易服务中心网站_装潢设计师_怎么让网站排名上去_精准网络营销推广

2024/10/30 23:04:39 来源:https://blog.csdn.net/George_huhu/article/details/140674094  浏览:    关键词:深圳市建设工程交易服务中心网站_装潢设计师_怎么让网站排名上去_精准网络营销推广
深圳市建设工程交易服务中心网站_装潢设计师_怎么让网站排名上去_精准网络营销推广

Redis 总结

导航

  • Redis 总结
    • 关于Redis
      • redis服务
      • redis 桌面客户端
      • 桌面图形客户端
    • Redis 常见命令
      • redis通用命令
      • String 类型
        • String的常见命令
      • hash类型
        • hash的常见命令
      • List 类型
      • set类型
      • sortedSet类型
    • Redis的Java客户端
      • SpringDataRedis
      • 序列化

关于Redis

  1. redis 是非关系型数据库,是基于内存的,是键值型数据库。
  2. 基于内存,所以读写速度快,性能强。
  3. 单线程,每个命令具有原子性。
  4. 支持数据持久化
  5. 支持主从集群、分片集群
  6. 支持多语言客户端

redis服务

redis-cli:是redis提供的命令行客户端
redis-server:是redis的服务端启动脚本
redis-sentinel:是redis的哨兵启动脚本
启动
systemctl start redis
停止
systemctl stop redis
重启
systemctl restart redis
查看状态
systemctl status redis
执行下面的命令,可以让redis开机自启:
systemctl enable redis

redis 桌面客户端

Redis安装完成后就自带了命令行客户端:redis-cli,使用方式如下:

redis-cli [options] [commonds]
其中常见的options有:

-h 127.0.0.1:指定要连接的redis节点的IP地址,默认是127.0.0.1
-p 6379:指定要连接的redis节点的端口,默认是6379
-a 123321:指定redis的访问密码
其中的commonds就是Redis的操作命令,例如:

ping:与redis服务端做心跳测试,服务端正常会返回pong
在这里插入图片描述

桌面图形客户端

https://github.com/lework/RedisDesktopManager-Windows/releases

Redis 常见命令

redis是常见的键值对数据库,key一般是字符串,value可以是以下类型:
在这里插入图片描述

redis通用命令

KEYS:查看符合模板的所有key
DEL :删除一个指定的key
EXISTS:判断key是否存在
EXPIRE:给一个key设置有效期,有效期到期时候该key自动删除
TTL:查看key剩余有效期

String 类型

String类型,也就是字符串类型,是Redis中最简单的存储类型。

其value是字符串,不过根据字符串的格式不同,又可以分为3类:

string:普通字符串
int:整数类型,可以做自增、自减操作
float:浮点类型,可以做自增、自减操作
字符串的最大空间不能超过512m。
在这里插入图片描述

String的常见命令

String的常见命令有:

  • SET:添加或者修改已经存在的一个String类型的键值对

  • GET:根据key获取String类型的value

  • MSET:批量添加多个String类型的键值对

  • MGET:根据多个key获取多个String类型的value

  • INCR:让一个整型的key自增1

  • INCRBY:让一个整型的key自增并指定步长,例如:incrby num 2 让num值自增2

  • INCRBYFLOAT:让一个浮点类型的数字自增并指定步长

  • SETNX:添加一个String类型的键值对,前提是这个key不存在,否则不执行

  • SETEX:添加一个String类型的键值对,并且指定有效期

hash类型

Hash类型,也叫散列,其value是一个无序字典,类似于Java中的HashMap结构。
String结构是将对象序列化为JSON字符串后存储,当需要修改对象某个字段时很不方便:

在这里插入图片描述
hash 结构可以对每个字段单独存,方便操作,如下图:

在这里插入图片描述

hash的常见命令
  • HSET key field value:添加或者修改hash类型key的field的值

  • HGET key field:获取一个hash类型key的field的值

  • HMSET:批量添加多个hash类型key的field的值

  • HMGET:批量获取多个hash类型key的field的值

  • HGETALL:获取一个hash类型的key中的所有的field和value

  • HKEYS:获取一个hash类型的key中的所有的field

  • HINCRBY:让一个hash类型key的字段值自增并指定步长

  • HSETNX:添加一个hash类型的key的field值,前提是这个field不存在,否则不执行

List 类型

Redis中List类型与Java中的LInkedListl类型相似,是一个双向链表结构,既可以支持正向检索也可以支持反向检索。
特征也与LinkedList相似: 有序、元素可以重复、插入和删除快、查询速度一般
常用来存储一个有序数据,例如:朋友圈点赞、评论列表
List的常见命令有:

  • LPUSH key element … :向列表左侧插入一个或多个元素
  • LPOP key:移除并返回列表左侧的第一个元素,没有则返回nil
  • RPUSH key element … :向列表右侧插入一个或多个元素
  • RPOP key:移除并返回列表右侧的第一个元素
  • LRANGE key star end:返回一段角标范围内的所有元素
  • BLPOP和BRPOP:与LPOP和RPOP类似,只不过在没有元素时等待指定时间,而不是直接返回null

set类型

Redis中Set结构和Java中的HashSet相似,可以看做是一个value为null的HashMap。因为是一个hash表,所以特征类似:无序、元素不可重复、查找快、支持交集、并集、差集等功能。
Set的常见命令有:

  • SADD key member … :向set中添加一个或多个元素
  • SREM key member … : 移除set中的指定元素
  • SCARD key: 返回set中元素的个数
  • SISMEMBER key member:判断一个元素是否存在于set中
  • SMEMBERS:获取set中的所有元素
  • SINTER key1 key2 … :求key1与key2的交集
    在这里插入图片描述

求交集:SINTER s1 s2

求s1与s2的不同:SDIFF s1 s2

sortedSet类型

Redis中sortedSet是可排序的set集合,与Java中的treeset相似,但是底层数据结构差别很大。sortedSet中的每一个元素都带有一个score属性,可以基于score属性对元素排序,底层是一个跳表(skipList)加hsah表。
SortedSet具有以下特性:可排序、不可重复、查询速度快。 因为可排序,所以可以作为排行榜功能的实现。
SortedSet的常见命令有:

  • ZADD key score member:添加一个或多个元素到sorted set ,如果已经存在则更新其score值
  • ZREM key member:删除sorted set中的一个指定元素
  • ZSCORE key member : 获取sorted set中的指定元素的score值
  • ZRANK key member:获取sorted set 中的指定元素的排名
  • ZCARD key:获取sorted set中的元素个数
  • ZCOUNT key min max:统计score值在给定范围内的所有元素的个数
  • ZINCRBY key increment member:让sorted set中的指定元素自增,步长为指定的increment值
  • ZRANGE key min max:按照score排序后,获取指定排名范围内的元素
  • ZRANGEBYSCORE key min max:按照score排序后,获取指定score范围内的元素
  • ZDIFF、ZINTER、ZUNION:求差集、交集、并集
    注意:所有的排名默认都是升序,如果要降序则在命令的Z后面添加REV即可,例如:
    升序获取sorted set 中的指定元素的排名:ZRANK key member
    降序获取sorted set 中的指定元素的排名:ZREVRANK key memeber

Redis的Java客户端

在Redis官网中提供了各种语言的客户端,地址:https://redis.io/docs/clients/

标记为*的就是推荐使用的java客户端,包括:

Jedis和Lettuce:这两个主要是提供了Redis命令对应的API,方便我们操作Redis,而SpringDataRedis又对这两种做了抽象和封装,因此我们直接以SpringDataRedis来学习。
Redisson:是在Redis基础上实现了分布式的可伸缩的java数据结构,例如Map、Queue等,而且支持跨进程的同步机制:Lock、Semaphore等待,比较适合用来实现特殊的功能需求。

SpringDataRedis

SpringData是Spring中数据操作的模块,包含对各种数据库的集成,其中对Redis的集成模块就叫做SpringDataRedis,官网地址:https://spring.io/projects/spring-data-redis

  • 提供了对不同Redis客户端的整合(Lettuce 和 Jedis)
  • 提供了RedisTemplate 统一API来操作Redis
  • 支持Redis的发布和订阅模型
  • 支持Redis哨兵和Redis集群
  • 支持基于Lettuce的响应式编程
  • 支持基于JDK、JSON、字符串、Spring对象的数据序列化及反序列化
  • 支持基于Redis的JDKCollection实现
    SpringDataReids中提供了RedisTemplate工具类,其中封装了各种对Redis的操作,并且将不同数据类型的操作API封装到不同的类型中
    在这里插入图片描述

序列化

RedisTemplate 默认使用jdk序列化,不方便读取,内存占用较大。
序列化器包括:
在这里插入图片描述自定义序列化工具:

@Configuration
public class RedisConfig {@Beanpublic RedisTemplate<String, Object> redisTemplate(RedisConnectionFactory connectionFactory){// 创建RedisTemplate对象RedisTemplate<String, Object> template = new RedisTemplate<>();// 设置连接工厂template.setConnectionFactory(connectionFactory);// 创建JSON序列化工具GenericJackson2JsonRedisSerializer jsonRedisSerializer = new GenericJackson2JsonRedisSerializer();// 设置Key的序列化template.setKeySerializer(RedisSerializer.string());template.setHashKeySerializer(RedisSerializer.string());// 设置Value的序列化template.setValueSerializer(jsonRedisSerializer);template.setHashValueSerializer(jsonRedisSerializer);// 返回return template;}
}

其中 GenericJackson2JsonRedisSerializer 会保存对象信息,为了节省内存空间,我们改成使用String序列化器。当需要完成Java对象存储的时候,手动完成序列化和反序列化。
因为存入和读取时的序列化及反序列化都是我们自己实现的,SpringDataRedis就不会将class信息写入Redis了。

这种用法比较普遍,因此SpringDataRedis就提供了RedisTemplate的子类:StringRedisTemplate,它的key和value的序列化方式默认就是String方式。这样也省略了上述的自定义序列化。
在这里插入图片描述

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com