Redis基础

1、Redis入门

Redis简介

  • Redis是用C语言开发的一个开源的高性能键值对(key-value)数据库,官方提供的数据是可以达到100000+的QPS(每秒内查询次数)。它存储的value类型比较丰富,也被称为结构化的NoSql数据库。
  • NoSql(Not Only SQL),不仅仅是SQL,泛指非关系型数据库。NoSql数据库并不是要取代关系型数据库,而是关系型数据库的补充

Redis应用场景

  • 缓存
  • 任务队列
  • 分布式锁

Redis下载与安装

  1. 将Redis安装包上传到Linux
  2. 减压安装包:tar -zxvf redis-4.0.0.tar.gz
  3. 安装Redis的以来环境gcc:yum install gcc-c++ -y
  4. 进入redis目录,进行编译:make
  5. 进入Redis的src目录安装:make install
  • Windows安装
    1. 直接将Redis压缩文件解压即可

Redis启动与停止

  • 启动redis-server 文件即可
    在这里插入图片描述

  • 后台启动

    1. 修改配置文件:改为yes
      在这里插入图片描述
    2. 后台启动:src/redis-server ./redis.conf
      在这里插入图片描述
  • Windows系统中启动Redis,直接双击 redis-server.exe 即可启动Redis服务,Redis服务默认端口号为6379

设置Redis密码和允许远程连接

  • 修改配置文件:requirepass后面是密码
    ![在这里插入图片描述](https://img-blog.csdnimg.cn/dceeab4e97e54a3bb70cd2fb40c73662.pn

  • 重新启动Redis
    在这里插入图片描述

  • 再次登录:提示报错认证
    在这里插入图片描述

  • 认证密码
    在这里插入图片描述

  • 连接时认证
    在这里插入图片描述


修改配置文件允许本地连接

  • 把这一个配置注释掉
    在这里插入图片描述

  • 然后重新启动Redis
    在这里插入图片描述

2、Redis数据类型

Redis存储的是key-value结构的数据,其中key是字符串类型,value有5种采用的数据类型:

  • 字符串 —— string
  • 哈希 —— hash
  • 列表 —— list
  • 集合 —— set
  • 有序集合 —— sorted set
    在这里插入图片描述

3、Redis常用命令

字符串string操作命令

  • SET key value —— 设置指定key的值
  • GET key —— 获取指定key的值
  • SETEX key seconds value —— 设置指定key的值,并将key的过期时间设为seconds秒
  • SETNX key value —— 只有在key不存在时设置key的值

哈希hash操作命令

Redis hash是一个string类型的field和value的映射表,hash特别适合用于存储对象

  • HSET key field value —— 将哈希表key中的字段field的值设为value
  • HGET key field —— 获取存储在哈希表中指定字段的值
  • HDEL key filed —— 删除存储在哈希表中的指定字段
  • HKEYS key —— 获取哈希表中所有字段
  • HVALS key —— 获取哈希表中所有值
  • HGETALL key —— 获取在哈希表中指定key的所有字段和值

列表list操作命令

Redis列表是简单的字符串列表,按照插入顺序排序

  • LPUSH key value1 value2 …… —— 将一个或多个值插入到列表头部
  • LRANGE key start stop —— 获取列表指定范围内的元素
  • RPOP key —— 移除并获取列表最后一个元素
  • LLEN key —— 获取列表长度
  • BRPOP key1 key2 …… timeout —— 移除并获取列表最后一个元素,如果列表没有元素会阻塞列表直到等待超时或发现可弹出元素为止

集合set操作命令

Redis set是string类型的无序集合。集合成员是唯一的,这就意味着集合中不能出现重复的数据

  • SADD key member1 member2 …… —— 向集合添加一个或多个成员
  • SMEMBERS key —— 返回集合中的所有成员
  • SCARD key —— 获取集合的成员数
  • SINTER key1 key2 …… —— 返回给定所有集合的交集
  • SUNION key1 key2 …… —— 返回所有给定集合的并集
  • SDIFF key1 key2 …… —— 返回给定所有集合的差集
  • SREM key member1 member2 …… —— 移除集合中一个或多个成员

有序集合sorted set操作命令

Redis sorted set有序集合是string类型元素的集合,且不允许重复的成员。每个元素都会关联一个double类型的分数(score)。Redis正是通过分数来为集合找那个的成员进行从小到大排序。有序集合的成员是唯一的。但分数却可以重复。

  • ZADD key score1 member1 score2 member2 —— 向有序集合添加一个或多个成员,或者更新已存在的成员的分数
  • ZRANGE key start stop [WITHSCORES] —— 通过索引区间返回有序集合中指定区间内的成员
  • ZINCRBY key increment member —— 有序集合中对指定成员的分数加上增量increment
  • ZREM key member …… —— 移除有序集合中的一个或多个成员

通用命令

  • KEYS pattern —— 查找所有负荷给定模式(pattern)的key
  • EXISTS key —— 检查给定key是否存在
  • TYPE key —— 返回key所存储的值的类型
  • TTL key —— 返回给定key剩余生存时间(TTL,time to live),以秒为单位
  • DEL key —— 该命令用于在key存在时删除key

4、在Java中操作Redis

介绍

Redis的Java客户端很多,官方推荐的有三种:

  • Jedis
  • Lettuce
  • Redisson

Spring 对 Redis 客户端进行了整合,提供了 Spring Data Redis,在Spring Boot项目中还提供了对应的Starter,即spring-boot-starter-data-redis

Jedis

Jedis的Maven坐标:

<dependency>
    <groupId>redis.clients</groupId>
    <artifactId>jedis</artifactId>
    <version>4.4.3</version>
</dependency>

使用Jedis操作Redis的步骤:

  • 获取连接
  • 执行操作
  • 关闭连接
public void testRedis(){
    // 1.获取连接
    Jedis jedis = new Jedis("localhost", 6379);
    // 2.执行具体的操作
    jedis.set("username","xiaowu");
    // 3.关闭连接
    jedis.close();
}

Spring Data Redis

在Spring Boot项目中,可以使用Spring Data Redis操作,Maven坐标

<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-data-redis</artifactId>
</dependency>

Spring Data Redis中提供了一个高度封装的类:RedisTemplate,针对Jedis客户端中大量api进行了归类封装,将同一类型操作封装为operation接口,具体分类如下:

  • ValueOperations:简单K-V操作
  • SetOperations:set类型数据操作
  • ZSetOperations:zset类型数据操作
  • HashOperations:针对hash类型数据的操作
  • ListOperations:针对list类型的数据操作

Redis相关配置

spring:
  application:
    name: spring-data-redis

  #Redis相关配置
  redis:
    host: localhost
    port: 6379
    #password 123456
    database: 0 #选择数据库(默认提供了16个数据库)
    jedis:
      pool:
        max-active: 8 #最大连接数
        max-wait: 1ms #连接池最大阻塞等待时间
        max-idle: 4 #连接池中的最大空闲连接
        min-idle: 0 #连接池中的最小空闲连接

注入RedisTemplate

@Autowired
private RedisTemplate redisTemplate;

测试

public void testString(){
    redisTemplate.opsForValue().set("city","tianjing");
}

由于默认对key做了序列化,所以我们需要修改默认的序列化规则
在这里插入图片描述
Redis配置类(配置序列化规则)

/**
 * Redis配置类
 */
@Configuration
public class RedisConfig {

    @Bean
    public RedisTemplate<String, Object> redisTemplate(RedisConnectionFactory redisConnectionFactory) {
        RedisTemplate<String, Object> redisTemplate = new RedisTemplate<>();
        redisTemplate.setConnectionFactory(redisConnectionFactory);
        GenericJackson2JsonRedisSerializer jackson2JsonRedisSerializer = new GenericJackson2JsonRedisSerializer();
        // 设置值(value)的序列化采用FastJsonRedisSerializer。
        redisTemplate.setValueSerializer(jackson2JsonRedisSerializer);
        // 设置键(key)的序列化采用StringRedisSerializer。
        redisTemplate.setKeySerializer(new StringRedisSerializer());
        redisTemplate.setHashKeySerializer(new StringRedisSerializer());
        redisTemplate.setHashValueSerializer(jackson2JsonRedisSerializer);
        redisTemplate.afterPropertiesSet();
        return redisTemplate;
    }


    @Bean
    public CacheManager cacheManager(RedisConnectionFactory redisConnectionFactory) {
        //初始化一个RedisCacheWriter
        RedisCacheWriter redisCacheWriter = RedisCacheWriter.nonLockingRedisCacheWriter(redisConnectionFactory);
        //设置CacheManager的值序列化方式为json序列化
        RedisSerializer<Object> jsonSerializer = new GenericJackson2JsonRedisSerializer();
        RedisSerializationContext.SerializationPair<Object> pair = RedisSerializationContext.SerializationPair
                .fromSerializer(jsonSerializer);
        RedisCacheConfiguration defaultCacheConfig = RedisCacheConfiguration.defaultCacheConfig()
                .serializeValuesWith(pair);
        //设置默认超过期时间是30秒
        defaultCacheConfig.entryTtl(Duration.ofSeconds(30));
        //初始化RedisCacheManager
        return new RedisCacheManager(redisCacheWriter, defaultCacheConfig);
    }
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
对于学习Redis基础知识,可以按照以下思路进行学习: 1. 了解Redis的概念和特点:首先需要了解Redis是什么,它的主要特点是什么,它为什么被广泛应用于缓存、消息队列、会话管理等场景。 2. 安装和配置Redis:根据你的操作系统,安装Redis并进行相关配置。可以参考Redis官方文档或其他教程来完成这一步。 3. 学习Redis的数据结构:Redis支持多种数据结构,如字符串、哈希、列表、集合和有序集合等。了解每种数据结构的特点、用途和操作命令,并通过实际操作来加深理解。 4. 掌握Redis的常用命令:学习Redis的常用命令,如get、set、hget、hset、lpush、lrange、sadd、smembers等,了解每个命令的具体用法和参数含义。 5. 理解Redis的持久化机制:了解Redis的RDB和AOF两种持久化方式,以及它们的优缺点。学习如何进行备份和恢复数据。 6. 学习Redis的事务和Lua脚本:了解Redis事务的基本概念和使用方法,以及如何使用Lua脚本来进行复杂的操作。 7. 深入了解Redis的性能优化和高可用方案:学习如何优化Redis的性能,包括配置调优、使用合适的数据结构、合理地使用缓存等。同时了解Redis的高可用方案,如主从复制、哨兵模式和集群模式。 8. 学习Redis与其他技术的结合:了解Redis如何与其他技术进行结合,如与Python、Java等编程语言的配合使用,以及与Spring、Django等框架的整合。 以上是学习Redis基础知识的一个思路,你可以根据自己的实际情况和需求进行学习和拓展。推荐参考一些经典的Redis教程和实战案例,通过实际操作和项目实践来提升自己的技能。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

小吴在敲Bug

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值