Redis-Day1基础篇(初识Redis, Redis常见命令, Redis的Java客户端)

Redis-Day1基础篇

  • 初识Redis
    • 认识NoSQL
    • 认识Redis
    • 安装Redis
      • 启动Redis
      • Redis客户端
  • Redis命令
    • 数据结构介绍
    • 通用命令
    • 操作命令
      • String
      • Hash
      • List
      • Set
      • SortedSet
  • Redis的Java客户端
    • 客户端对比
    • Jedis客户端
      • Jedis快速入门
      • Jedis连接池
    • SpringDataRedis客户端
      • SpringDataRedis概述
      • SpringDataRedis快速入门
      • RedisTemplate的RedisSerializer
      • StringRedisTemplate
      • RedisTemplate操作Hash类型
  • 来源
  • Gitee地址

初识Redis

认识NoSQL

在这里插入图片描述

认识Redis

  • 键值(key-value)型, value支持多种不同数据结构, 功能丰富
  • 单线程, 每个命令具备原子性
  • 低延迟, 速度快(基于内存, io多路复用, 良好的编码)
  • 支持数据持久化
  • 支持主从集群, 分片集群
  • 支持多语言客户端

安装Redis

  • 安装Redis依赖
    yum install -y gcc tcl
    
  • 上传安装包并解压
    将压缩包放到/usr/local/src目录下
    # 解压缩
    tar -zxvf redis-6.2.6.tar.gz
    # 进入redis目录
    cd redis-6.2.6
    # 运行编译命令
    make && make install
    
    默认的安装路径在/usr/local/bin目录下, 该目录默认配置环境变量
    redis-cli:是redis提供的命令行客户端
    redis-server:是redis的服务端启动脚本
    redis-sentinel:是redis的哨兵启动脚本
    

启动Redis

  • 默认启动(前台启动)
    redis-server
    
  • 指定配置启动(后台启动)
    # 进入redis安装包目录
    cd /usr/local/src/redis-6.2.6
    # 备份配置文件
    cp redis.conf redis.conf.bck
    
    修改配置文件
    # 监听的地址,默认是127.0.0.1,会导致只能在本地访问。修改为0.0.0.0则可以在任意IP访问,生产环境不要设置为0.0.0.0
    bind 0.0.0.0
    # 守护进程,修改为yes后即可后台运行
    daemonize yes 
    # 密码,设置后访问Redis必须输入密码
    requirepass 123456
    # 监听的端口
    port 6379
    # 工作目录,默认是当前目录,也就是运行redis-server时的命令,日志、持久化等文件会保存在这个目录
    dir .
    # 数据库数量,设置为1,代表只使用1个库,默认有16个库,编号0~15
    databases 1 # 没改
    # 设置redis能够使用的最大内存
    maxmemory 512mb # 没改
    # 日志文件,默认为空,不记录日志,可以指定日志文件名
    logfile "redis.log"
    
    启动Redis
    # 进入redis安装目录
    cd /usr/local/src/redis-6.2.6
    # 启动
    redis-server redis.conf
    
  • 开机自启
    首先, 新建一个配置文件
    vi /etc/systemd/system/redis.service
    
    内容如下
    [Unit]
    Description=redis-server
    After=network.target[Service]
    Type=forking
    ExecStart=/usr/local/bin/redis-server /usr/local/src/redis-6.2.6/redis.conf
    PrivateTmp=true[Install]
    WantedBy=multi-user.target
    
    然后重载系统服务
    systemctl daemon-reload
    
    现在,我们可以用下面这组命令来操作redis了
    # 启动
    systemctl start redis
    # 停止
    systemctl stop redis
    # 重启
    systemctl restart redis
    # 查看状态
    systemctl status redis
    
    执行下面的命令,可以让redis开机自启
    systemctl enable redis
    

Redis客户端

  • 命令行客户端

    redis-cli [options] [commonds]
    

    常见的options有

    • -h 127.0.0.1: 指定要连接的redis节点的ip地址, 默认127.0.0.1
    • -p 6379: 指定要连接的redis节点的端口, 默认6379
    • -a 123456: 指定redis的访问密码
    • 安全的密码验证方式: 启动redis-cli后输入AUTH 123456

    commonds是redis的操作命令

    • ping: 与redis服务端做心跳测试, 服务端支持会返回pong
    • 不知道commond时, 进入redis-cli的交互控制台

    选择库

    select 0
    
  • 图形化客户端
    安装包: https://github.com/lework/RedisDesktopManager-Windows/releases

Redis命令

数据结构介绍

在这里插入图片描述

通用命令

  • keys: 查看符合模板的所有key, 不建议在生产环境设备上使用
  • del: 删除一个指定的key
  • exists: 判断key是否存在
  • expire: 给一个key设置有效期, 有效期到期时该key会被自动删除
  • ttl: 查看一个key的剩余有效期(-2表示不存在, -1表示永久)

操作命令

String

value是字符串类型, 底层都是字节数组形式存储, 分为3类:

  • string: 普通字符串
  • int: 整数类型, 可以自增减
  • float: 浮点类型, 可以自增减

常见命令

  • 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类型的键值对,并且指定有效期

Redis的key的格式(建议)

  • [项目名]:[业务名]:[类型]:[id]

Hash

Hash类型, value是一个无序字典, 与java的HashMap类似

  • 场景: string结构是将对象序列化为JSON字符串后存储, 修改某个字段不方便

常见命令

  • 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
  • HVALS: 获取一个hash类型的key中的所有的value
  • HINCRBY: 让一个hash类型key的字段值自增并指定步长
  • HSETNX: 添加一个hash类型的key的field值,前提是这个field不存在,否则不执行

List

与java的LinkedList类似, 可以看作是双向链表结构. 支持双向检索

  • 有序
  • 元素可以重复
  • 插入和删除快
  • 查询速度一般

常用语法

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

Set

与java的HashSet类似

  • 无序
  • 元素不可重复
  • 查找快
  • 支持交集, 并集, 差集等功能

常见命令

  • SADD key member ...: 向set中添加一个或多个元素
  • SREM key member ...: 移除set中的指定元素
  • SCARD key: 返回set中元素的个数
  • SISMEMBER key member: 判断一个元素是否存在于set中
  • SMEMBERS: 获取set中的所有元素
  • SINTER key1 key2 ...: 求key1与key2的交集
  • SDIFF key1 key2...: key1与key2的差集
  • SUNION key1 key2..: 求key1和key2的并集

SortedSet

是一个可排序的set集合, 与java中的TreeSet有些类似, 但底层数据结构差别很大.SortedSet中的每一个元素都带有一个score属性, 基于score属性对元素排序, 底层是一个跳表(SkipList)加Hash表.

  • 可排序
  • 元素不重复
  • 查询速度快

可用来实现排行榜的功能

常见命令

  • ZADD key score member: 添加一个或多个元素到sorted set,如果已经存在则更新其score值
  • ZREM key member: 删除sorted set中的一个指定元素
  • ZSCORE key member: 获取srted 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: 按照sore排序后,获取指定score范围内的元素
  • ZDIFF、ZINTER、ZUNION: 求差集、交集、并集
  • 注意: 默认升序, 降序需要在命令的Z后面添加REV: ZREVRANK

Redis的Java客户端

客户端对比

Spring Data Redis 整合了 Jedis 和 lettuce
在这里插入图片描述

Jedis客户端

Jedis快速入门

  1. 引入依赖
    <!-- Jedis -->
    <dependency><groupId>redis.clients</groupId><artifactId>jedis</artifactId><version>3.7.0</version>
    </dependency>
    <!-- 单元测试 -->
    <dependency><groupId>org.junit.jupiter</groupId><artifactId>junit-jupiter</artifactId><version>5.7.0</version><scope>test</scope>
    </dependency>
    <!-- lombok -->
    <dependency><groupId>org.projectlombok</groupId><artifactId>lombok</artifactId><version>1.18.18</version><scope>test</scope>
    </dependency>
    
  2. 使用
    import lombok.extern.slf4j.Slf4j;
    import org.junit.jupiter.api.AfterEach;
    import org.junit.jupiter.api.BeforeEach;
    import org.junit.jupiter.api.Test;
    import redis.clients.jedis.Jedis;import java.util.Map;@Slf4j
    public class JedisTest {private Jedis jedis;// 1. 建立连接@BeforeEachvoid setUp(){// 建立连接jedis = new Jedis("192.168.174.133", 6379);// 密码验证jedis.auth("123456");// 选择库, 默认0jedis.select(0);}// 4. 释放资源@AfterEachvoid tearDown(){// 释放资源if(jedis != null){jedis.close();}}// 2. 测试String@Testvoid testString(){// 插入数据, 方法名就是redis命令名String res = jedis.set("name", "zhangsan");System.out.println("result = " + res);// 获取数据String name = jedis.get("name");System.out.println("name = " + name);}// 3. 测试Hash@Testvoid testHash() {// 插入数据jedis.hset("user:1", "name", "tom");jedis.hset("user:1", "age", "20");// 获取数据Map<String, String> map = jedis.hgetAll("user:1");System.out.println(map);}
    }
    

Jedis连接池

  • 工具类
    import redis.clients.jedis.Jedis;
    import redis.clients.jedis.JedisPool;
    import redis.clients.jedis.JedisPoolConfig;public class JedisConnectionFactory {private static final JedisPool jedisPool;static {JedisPoolConfig jedisPoolConfig = new JedisPoolConfig();// 最大连接jedisPoolConfig.setMaxTotal(8);// 最大空闲连接jedisPoolConfig.setMaxIdle(8);// 最小空闲连接jedisPoolConfig.setMinIdle(0);// 设置最长等待时间, msjedisPoolConfig.setMaxWaitMillis(200);jedisPool = new JedisPool(jedisPoolConfig, "192.168.174.133", 6379,1000, "123456");}public static Jedis getJedis(){return jedisPool.getResource();}
    }
    
  • 使用
    ...
    public class JedisTest {private Jedis jedis;// 建立连接@BeforeEachvoid setUp(){// 建立连接// jedis = new Jedis("192.168.174.133", 6379);jedis = JedisConnectionFactory.getJedis();...}...
    }
    

SpringDataRedis客户端

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实现

SpringDataRedis提供了RedisTemplate工具类
在这里插入图片描述

SpringDataRedis快速入门

  1. 引入依赖
    <!-- Redis依赖 -->
    <dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-data-redis</artifactId>
    </dependency>
    <!-- 连接池依赖 -->
    <dependency><groupId>org.apache.commons</groupId><artifactId>commons-pool2</artifactId>
    </dependency>
    
  2. 配置文件
    spring:data:redis:host: 192.168.174.133port: 6379password: 123456lettuce:pool:max-active: 8 # 最大连接max-idle: 8 # 最大空闲连接min-idle: 0 # 最小空闲连接max-wait: 100 # 设置最长等待时间, ms
    
  3. 使用
    @SpringBootTest
    class SpringdataredisDemoApplicationTests {@Autowiredprivate RedisTemplate redisTemplate;@Testvoid testString() {// 插入一条string类型数据redisTemplate.opsForValue().set("name", "李四");// 读取一条string类型数据Object name = redisTemplate.opsForValue().get("name");System.out.println("name = " + name);}}
    

RedisTemplate的RedisSerializer

RedisTemplate可以接收任意Object作为值写入Redis, 但是写入前会把Object序列化为字节形式, 默认是采用JDK序列化

  • 可读性差
  • 内存占用较大

使用JSON序列化, 配置类如下:

import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.data.redis.connection.RedisConnectionFactory;
import org.springframework.data.redis.core.RedisTemplate;
import org.springframework.data.redis.serializer.GenericJackson2JsonRedisSerializer;
import org.springframework.data.redis.serializer.RedisSerializer;@Configuration
public class RedisConfig {@Beanpublic RedisTemplate<String, Object> redisTemplate(RedisConnectionFactory redisConnectionFactory){// 创建RedisTemplate对象RedisTemplate<String, Object> redisTemplate = new RedisTemplate<>();// 设置连接工厂redisTemplate.setConnectionFactory(redisConnectionFactory);// 创建JSON序列化工具GenericJackson2JsonRedisSerializer jsonRedisSerializer = new GenericJackson2JsonRedisSerializer();// 设置Key的序列化redisTemplate.setKeySerializer(RedisSerializer.string());redisTemplate.setHashKeySerializer(RedisSerializer.string());// 设置Value的序列化redisTemplate.setValueSerializer(jsonRedisSerializer);redisTemplate.setHashValueSerializer(jsonRedisSerializer);// 返回return redisTemplate;}}

StringRedisTemplate

  • JSON序列化器会将类的class类型写入json结果中, 插入redis, 会带来额外的内存开销
  • 统一使用String序列化器, 要求只能存储String类型的key和value, 需要存储对象时, 手动完成对象的序列化和反序列化
  • Spring默认提供了StringRedisTemplate类
    @SpringBootTest
    class StringRedisTemplateTests {@Autowiredprivate StringRedisTemplate stringRedisTemplate;// SpringMVC框架默认使用的JSON处理工具private static final ObjectMapper mapper = new ObjectMapper();@Testvoid testSaveUser() throws JsonProcessingException {// 创建对象User user = new User("jerry", 21);// 手动序列化String json = mapper.writeValueAsString(user);// 写入数据stringRedisTemplate.opsForValue().set("user:2", json);// 获取数据String jsonUser = stringRedisTemplate.opsForValue().get("user:2");// 手动反序列化User user1 = mapper.readValue(jsonUser, User.class);System.out.println("user1 = " + user1);}
    }
    

RedisTemplate操作Hash类型

...@SpringBootTest
class StringRedisTemplateTests {@Autowiredprivate StringRedisTemplate stringRedisTemplate;...@Testvoid testHash() {stringRedisTemplate.opsForHash().put("user:3", "name", "tom");stringRedisTemplate.opsForHash().put("user:3", "age", "21");Map<Object, Object> entries = stringRedisTemplate.opsForHash().entries("user:3");System.out.println(entries);}
}

来源

黑马程序员. Redis入门到实战教程

Gitee地址

https://gitee.com/Y_cen/redis

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/164065.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

boardmix AI思维导图,一键自动生成思维导图!

在日常学习和工作中&#xff0c;我们常常需要记忆和整理大量的知识点和思维结构。 此时&#xff0c;思维导图的存在就大大方便了我们的工作。与传统的文本笔记不同&#xff0c;思维导图可以结合文字、图像、颜色等多种元素&#xff0c;帮助我们更好地整理和分析知识的关系&…

centos7上用docker部署redis

1. 下载redis镜像 docker pull redis docker images # 查看镜像是否下载成功2. 安装redis容器 2.1 先准备好配置文件redis.conf vi /data/redis/redis.conf写入配置信息&#xff0c;appendonly yes&#xff0c;如果需要给redis配置密码&#xff0c;可以写入requirepass root…

如何选择更快更稳定的存储服务器

如何选择更快更稳定的存储服务器 存储介质&#xff1a;存储服务器的主要存储介质包括固态硬盘&#xff08;SSD&#xff09;和机械硬盘&#xff08;HDD&#xff09;。相比于机械硬盘&#xff0c;固态硬盘具有更高的读写速度和更低的延迟&#xff0c;因此能够提供更快的数据传输…

python安装的记录

python setup.py install --user

(附程序)AD采集中的10种经典软件滤波程序优缺点分析

前言 本次我们学习一下AD采集的一些简单的软件滤波算法并分析优缺点 本篇博客大部分是自己收集和整理&#xff0c;如有侵权请联系我删除。 AD采样点的电压多少有点起伏波动&#xff0c;经运放放大后电压的波动如果超过ADC的分辩率&#xff0c;则显示的值会出现波动。波动如…

RTOS的任务触发底层逻辑

&#xff08;定时器用于计时和触发事件&#xff0c;任务则由调度器进行调度和执行&#xff1a;每当时钟节拍到达时&#xff0c;系统会触发一个称为 tick 中断的事件。当 tick 中断发生时&#xff0c;操作系统会在中断服务例程中执行一定的处理&#xff0c;其中包括更新任务的运…

C++算法入门练习——相同的二叉查找树

将第一组n​个互不相同的正整数先后插入到一棵空的二叉查找树中&#xff0c;得到二叉查找树T1​&#xff1b;再将第二组n个互不相同的正整数先后插入到一棵空的二叉查找树中&#xff0c;得到二叉查找树T2​。判断T1​和T2​​是否是同一棵二叉查找树。 二叉查找(搜索)树定义&am…

Halcon学习笔记

目录 一.简介 一.简介 Halcon和OpenCV在工业应用中的区别&#xff1a; OpenCV的精度没Halcon高&#xff1b;OpenCV没有模板匹配&#xff0c;Halcon有&#xff0c;而且Halcon匹配的精度更高。

DALSA.SaperaLT.SapClassBasic无法加载,试图加载格式不正确的程序,c#

情景&#xff1a;用c#wpf写DALSA线扫相机的项目&#xff0c;生成时不报错&#xff0c;运行到DALSA相关的代码就报错找不到dll&#xff08;DALSA的技术支持没给到任何支持 &#xff09; 一.根据框架选择dll 如果是.net framework框架&#xff08;比如说.net480&#xff09;&am…

一份全面「梳理LLM幻觉问题」的综述

文章目录 一文全面梳理「LLM 幻觉问题」1. 幻觉的分类2. 幻觉的来源2.1 幻觉来自数据2.2 幻觉来自训练2.3 幻觉来自生成/推理 3. 幻觉的检测3.1 事实性幻觉的检测3.2 忠实性幻觉的检测 4. 幻觉的评估5. 幻觉的解决 一文全面梳理「LLM 幻觉问题」 相信大家在使用ChatGPT或者其他…

vue3源码

/*! Vue.js v2.6.14© 2014-2021 Evan YouReleased under the MIT License. */ (function (global, factory) { typeof exports ‘object’ && typeof module ! ‘undefined’ ? module.exports factory() : typeof define ‘function’ && define.am…

PC8259(CC-CV控制)同步降压芯片5V/4.8A 输出频率可调 带电流限制 QFN20封装

概述 PC8259是一个同步降压转换器输出电流为4.8A在9V至36V。外部关闭功能可以由逻辑电平控制以下拉COMP/EN引脚&#xff0c;然后进入待机模式。外部补偿使反馈控制具有良好的线性以及具有灵活外部设计的负载调节。PC8259在CC&#xff08;恒定输出电流&#xff09;模式或CV&…

python数据结构与算法-17_二叉查找树

二叉查找树(BST) 二叉树的一种应用就是来实现堆&#xff0c;今天我们再看看用二叉查找树(Binary Search Tree, BST)。 前面有章节说到了查找操作&#xff0c;包括线性查找、二分查找、哈希查找等&#xff0c;线性查找效率比较低&#xff0c;二分又要求必须是有序的序列&#x…

亚马逊卖家不想被平台限制,应如何脱离平台,建立自己的跨境独立站?

随着跨境电商的快速发展&#xff0c;越来越多的卖家选择在亚马逊等电商平台上销售自己的产品。然而&#xff0c;这些平台往往会限制卖家的经营行为&#xff0c;收取高额的佣金和费用&#xff0c;给卖家带来了很大的压力和风险。因此&#xff0c;一些卖家开始考虑脱离电商平台&a…

Flink之状态TTL机制内容详解

1 状态TTL机制 状态的 TTL机制就是Flink提供的自动化删除状态中的过期数据,配置 TTL的 API可以做到对状态中的数据进行冷热数据分离,将热数据一直保存在状态存储器中,将冷数据进行定期删除. 1.1 API简介 TTL常用API如下: API注解setTtl(Time.seconds(…))配置过期时长,当状态…

Docker可视化管理界面工具Portainer安装

Portainer是Docker容器管理界面工具&#xff0c;可以直观的管理Docker。 部署也很简单&#xff1a; 官方安装文档地址 1、创建数据卷 docker volume create portainer_data2、下载允许容器 docker run -d -p 8000:8000 -p 9443:9443 --name portainer --restartalways -v /v…

放弃无谓的「技术氛围」幻想,准备战斗

大型科技公司每年都招聘大量研发人才&#xff0c;这给了很多人一种错觉&#xff0c;认为是「技术」导致了这些公司的成功&#xff0c;其实他们的成功是技术推动的市场战略的成功&#xff0c;是市场需要某项服务&#xff0c;才需要研发人员夜以继日的埋头苦干。资本绝不会做亏本…

vue2 element el-transfer穿梭框组件支持拖拽及排序 已封装,随取随用

项目场景&#xff1a; 项目中有个功能用到穿梭框组件&#xff0c;新版本需要支持穿梭框组件排序&#xff0c;由于element2版本中的穿梭框组件本身不支持排序功能 在此不仅需要支持随意更换顺序&#xff0c;还支持从一侧拖拽至另一侧&#xff0c;具体功能效果图如下&#xff1…

为什么JSX只能在函数的返回语句中使用

JSX只能在函数的返回语句中使用&#xff0c;因为JSX本质上是一种声明式的语法&#xff0c;用于描述React组件的结构和外观。在函数的返回语句中使用JSX&#xff0c;可以将JSX表达式嵌入到组件的输出中。 当我们编写一个React组件时&#xff0c;我们通常需要定义一个Render函数…

消息中间件——RabbitMQ(五)快速入门生产者与消费者,SpringBoot整合RabbitMQ!

前言 本章我们来一次快速入门RabbitMQ——生产者与消费者。需要构建一个生产端与消费端的模型。什么意思呢&#xff1f;我们的生产者发送一条消息&#xff0c;投递到RabbitMQ集群也就是Broker。 我们的消费端进行监听RabbitMQ&#xff0c;当发现队列中有消息后&#xff0c;就进…