Redis【超详细】

Redis 是一个基于内存的key-value结构的数据库

一、redis的安装

1.1、安装步骤

1)安装Redis依赖

Redis是基于c语言编写的,因此需要安装对应的gcc环境

yum install -y gcc tcl

2)进入/usr/local/src/目录上传并解压安装包

解压:

tar -zxvf 安装包名

3)解压成功后进入解压的文件目录

运行编译指令:

make && make install

注意:如果没有报错,表示安装成功,默认安装路径为/user/lcoal/bin目录下

1.2、启动方式

1)前台启动

前台启动,会阻塞整个窗口,窗口关闭或者停止,Redis也会停止

redis-server

2)后台启动

修改Redis的配置文件,配置文件就在解压的安装包下,名称为redis.conf,修改配置文件,一般先进行备份

# 将守护进程修改为yes就可以在后台运行
daemonize yes

修改成功后启动redis时,只需要在命令后面加上配置文件名

redis-server redis.con

1.3、开机自启

通过配置设置开机自启,创建一个系统服务文件

1)创建系统服务文件

vi /etc/systemd/system/redis.service

2)设置文件内容为

[Unit]
Description=redis-server
After=network.target
​
[Service]
Type=forking
# 这行配置内容要根据redis的安装目录自定义路径
ExecStart=/usr/local/bin/redis-server /usr/local/src/redis-6.2.6/redis.conf
PrivateTmp=true
​
[Install]
WantedBy=multi-user.target

3)重载系统服务:

systemctl daemon-reload

之后就可以使用systemctl命令操作redis

1.4、Redis其他配置

# 设置访问Redis的访问密码
requirepass 密码
​
# 监听端口
port 6379
​
# 设置允许访问的地址,默认是127.0.0.1,会导致只能在本地访问,设置为0.0.0.0就可以在任何IP下访问
bind 0.0.0.0
​
# 数据库数量,设置为1,代表只使用一个数据库,默认有16个库
databases 1
​
# 设置redis最大使用的内存
maxmemory 512mb
​
# 日志文件,默认为空,不记录日志,可以指定日子文件名
logfile "文件名"

1.4、使用Docker安装

普通安装redis后,redis默认只能够本地连接(127.0.0.1),不能进行远程访问;

常规步骤:

  • 安装redis镜像:拉取官方的最新版本的镜像

    docker pull redis:latest
  • 查看redis镜像:查看是否已安装了 redis

    docker images
  • 运行容器

    docker run -itd --name myRedis -p 6379:6379 redis
  • 查看容器安装成功

    docker ps

支持远程访问:

  • 安装redis镜像:拉取官方的最新版本的镜像

    docker pull redis:latest
  • 新建data和conf两个文件夹,位置随意

    mkdir -p /root/docker/redis/data
    mkdir -p /root/docker/redis/conf
  • 增加配置文件 redis.conf

    在刚才新建的redis/conf中新建文件redis.conf,内容如下:

    #bind 127.0.0.1 //允许远程连接
    protected-mode no
    appendonly yes //持久化
    requirepass 123456 //密码

注意:

1、以上文件(redis.conf)内容行与行之间不能带有空格,否则新建容器后,容器状态为stopped,无法启动;

2、如果配置了redis密码,在配置时除了需要redis的ip端口号外,也需要配置redis密码;

  • 创建redis容器并启动:

    docker run --name myRedis -p 6379:6379 -v /root/docker/redis/data:/data -v /root/docker/redis/conf/redis.conf:/etc/redis/redis.conf -d redis redis-server /etc/redis/redis.conf
  • 启动成功,查看状态

    docker ps

二、常用指令

2.1、常用数据类型

Redis存储的是key-value结构的数据,其中key是字符串类型,value有五种常用到的数据类型

  • String —— 字符串类型(最常用)

  • Hash —— 字典类型(最常用)

  • List —— 列表类型

  • Set —— 集合类型

  • ZSet —— 有序集合类型

2.2、字符串常用命令

字符串类型string:普通字符串,Redis中最简单的数据类型

指令说明
set key value设置指定key的值
get key获取指定key的值
setex key seconds value设置置顶key的值,并将key的过期时间设置为seconds秒
setnx key value只有在key不存在时设置value的值

e g:

// 设置指定key所对应值
set name lihua
​
// 获取指定key的值
get name
​
// 设置指定key的有效时间为20秒
setex age 20 zhang
​
// 当设置的key不存在时才会设置对应的值,存在时不设置
setnx score 98      // 不存在时返回1,存在时返回0

2.3、哈希常用命令

哈希hash:也叫散列,类似于java中的HashMap结构,hash特别适合存储对象

指令说明
hset key field value将哈希表中的字段field的值设置为value
hget key field获取存储在哈希表中指定字段的值
hdel key field删除存储在哈希表中指定字段的值
hkeys key获取哈希表中的所有字段
hvals key获取哈希表中所有值

e g:

// 设置ID属性为2的人的name属性为zhang
hset 2 name zhang
​
// 获取ID属性为2的问的name属性的值
hget 2 name
​
// 删除id属性为2的人的name属性的值
hdel 2 name
​
// 获取ID属性为2的人的所有字段
hkeys 2
​
// 获取ID属性为2的人的所有字段值
hvals 2

2.4、列表常用命令

列表list:按照插入顺序排序,可以有重复元素,类似java中的linkelist

指令说明
lpush key value1 [value2]将一个或多个值插入到列表的头部
lrange key start stop获取列表指定范围内的元素
rpop key移除并获取列表最后一个元素
llen key获取类表的长度

eg:

// 向对应key中插如两个值
lpush mylist 23 43
​
// 获取对应key的指定范围内的元素(头部到尾部使用0 -1表示)
lrange mylist 0 -1
​
// 删除并获取列表中的最后一个
rpop mylist
​
// 获取指定列表的长度
llen mylist

2.5、集合常用命令

集合set:无序集合,没有重复元素,类似于java中的HashSet

指令说明
sadd key member1 [member2]向集合中添加一个或多个成员
smembers key返回集合中的所有成员
scard key获取集合的成员数
sinter key1 [key2]返回所有指定集合的交集
sunion key1 [key2]返回所有集合的并集
srem key member1 [member2]删除集合中一个或多个成员

e g:

// 向集合中添加两个成员
sadd myset 223 344
​
// 返回集合中的所有元素
smembers myset
​
// 获取集合的成员数
scard myset
​
// 返回两个集合的交集
sinter myset1 myset2
​
// 返回两个集合的并集
sunion myset2 myset2
​
// 删除集合中的元素
srem myset 223

2.6、有序集合常用命令

有序集合sorted set |zset:集合中每个元素关联一个double类型的分数,根据分数生序排序,没有重复元素

指令说明
zadd key score1 member1 [score2 member2]向有序集合中体添加一个或多个成员
zrange key start stop [withscores]通过索引区间返回有序集合中的指定区间的元素
zincrby key increament member有序集合中对指定成员的分数加上增量increament
zrem key member [member]移除有序集合中的一个或者多个元素

eg:

// 向有序集合中添加一个成员并指定a的score值为10.0
zadd zset 10.0 a
​
// 查看有序集合中的所有成员的元素
zrange zset 0 -1
​
// 查看有序集合中的所有成员的元素和分数
zrange zset 0 -1 withscore
​
// 对有序成员中的a元素的分数值加5
zincrby zset 5.0 a
​
// 删除有序集合中的指定元素
zrem zset b

2.7、通用命令

Redis的通用命令就是部分数据类型的,都可以使用的命令

命令说明
keys pattem查找所有符合给定模式pattem的key
exists key检查给定的key是否存在
type key返回key所存储的数据类型
del key1 [key2]删除指定存在的key

eg:

// 返回所有的key
keys *// 返回以set开头的所有key
keys set*
​
// 检查具体key是否存在
exists tex
​
// 返回对应key存储的数据类型
type tex
​
// 删除key
del tex

三、在java程序中操作redis

在java程序中一般使用Spring Data Redis操作redis数据库

3.1、redis的java客户端

Redis的java客户端有很多,常用的有几种:

  • Jedis

  • Lettuce

  • Spring Data Redis

Spring Data Redis是Spring的一部分,对Redis底层开发包进行了高度封装

3.2、Spring Data Redis的使用方法

操作步骤:

  • 导入Spring Data Redis的maven坐标

<dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-data-redis</artifactId>
</dependency>
  • 配置Redis数据源

 redis:host: IP地址port: 端口号password: 密码database: 10    # 表示使用10号数据库,redis默认创建16个数据库
  • 编写配置类,创建RedisTemplate对象

import lombok.extern.slf4j.Slf4j;
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.StringRedisSerializer;
​
/*** Redis配置类*/
@Configuration
@Slf4j
public class RedisConfiguration {
​@Beanpublic RedisTemplate redisTemplate(RedisConnectionFactory redisConnectionFactory){log.info("开始创建Redis模版对象···");RedisTemplate redisTemplate = new RedisTemplate();// 设置redis的链接工厂对象redisTemplate.setConnectionFactory(redisConnectionFactory);// 设置redis key的序列化对象redisTemplate.setKeySerializer(new StringRedisSerializer());return redisTemplate;}
}
  • 通过RedisTemplate对象中的opsFor***来获取具体对象操作Redis,这里列举个别

/*** Redis测试类*/
@SpringBootTest
public class RedisTemplateText {@Autowiredprivate RedisTemplate redisTemplate;@Testpublic void textRedisType(){/*** 操作字符串类类型数据*/// 添加字符串类型数据-并设置有效时间redisTemplate.opsForValue().set("name","zhangshanc",20, TimeUnit.MILLISECONDS);// 对应key不存在时设置对应的key的值--对应redis中的setnx指令redisTemplate.opsForValue().setIfAbsent("age","12");
​/*** 操作哈希类型数据--其他指令见名知意*/// 添加hash类型的数据使用put--对应redis中的指令为hsetredisTemplate.opsForHash().put("11","name","tom");}
}

注意:redis中通用类型的数据直接使用RedisTemplate对象直接操作

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

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

相关文章

【APK】SDKManager运行后闪退

本地JDK已安装&#xff0c;且配置了环境变量&#xff0c;未安装 android studiio 问题描述&#xff1a;右键以管理员身份运行 SDKManager&#xff0c;终端窗口闪退 问题原因&#xff1a;未找到正确的Java路径 解决办法&#xff1a; 1.修改tools目录下的 android.bat 文件&am…

langchain 入门中篇:数据封装,Memory 封装

数据的处理流程可以看一张图来帮助理解 数据来源可以是网络&#xff0c;可以是邮件&#xff0c;可以是本地文件 经过 Document Loaders 加载&#xff0c;再在 Transform 阶段对文档进行 split, filter, translate, extract metadata 等操作&#xff0c;之后在 Embed 阶段进行向…

Keil用ST-LINK下载STM32程序后不自动运行

之后程序可以运行了&#xff0c;但是串口还没有输出&#xff0c;在debug模式下都是ok的。

加权 KNN 算法的原理与详解

加权kNN&#xff0c;k近邻算法的增强改进版本。 加权KNN算法 近邻算法&#xff08;k-Nearest Neighbors, kNN&#xff09;是一种用于分类和回归的非参数方法。它的基本思想是“看邻居”&#xff0c;即通过查找离目标点最近的 K 个数据点&#xff0c;来判断目标点的类别或数值。…

docker安装elasticesarch-head

安装 Elasticsearch-Head 通常涉及以下步骤&#xff1a; 拉取 Elasticsearch-Head 的 Docker 镜像。 运行 Elasticsearch-Head 容器并连接到 Elasticsearch 实例。 以下是具体的命令&#xff1a; 拉取 Elasticsearch-Head 的 Docker 镜像 docker pull mobz/elasticsearch-…

Sqlserver 如何创建全局只读账号?

由于SQL Server不支持全局数据库权限&#xff0c;因此需要在每个数据库中创建用户并授予其只读权限。可以使用动态SQL脚本来为所有现有数据库设置权限&#xff0c;具体脚本如下 ##创建登陆账号CREATE LOGIN user01 WITH PASSWORD password; ##除了系统库外给user01 db_datare…

FactoryBean原理及用法

它的作用是用制造创建过程较为复杂的产品, 如 SqlSessionFactory, 但 Bean 已具备等价功能 使用 被 FactoryBean 创建的产品 会认为创建、依赖注入、Aware 接口回调、前初始化这些都是 FactoryBean 的职责, 这些流程都不会走 唯有后初始化的流程会走, 也就是产品可以被代理增…

学习aurora64/66b.20240703

简介 The AMD LogiCORE™IP Aurora 64B/66B core是一种可扩展的轻量级高数据速率链路层协议&#xff0c;用于高速串行通信。该协议是开放的&#xff0c;可以使用AMD设备技术实现。 Aurora 64B/66B是一种轻量级的串行通信协议&#xff0c;适用于多千兆位链路 (如下图所示)。它…

【MATLAB源码-第139期】基于matlab的OFDM信号识别与相关参数的估计,高阶累量/小波算法调制识别,循环谱估计,带宽估计,载波数目估计等等。

操作环境&#xff1a; MATLAB 2022a 1、算法描述 在现代无线通信系统中&#xff0c;正交频分复用&#xff08;OFDM&#xff09;因其高效的频谱利用率、强大的抗多径衰落能力以及灵活的带宽分配等优势&#xff0c;成为了一种非常重要的调制技术。然而&#xff0c;随着无线通信…

采沙船智能监测识别摄像机

对于现代河流管理来说&#xff0c;采沙船智能监测识别摄像机正逐渐成为解决非法采砂和保护河流生态环境的重要工具。这类摄像机通过先进的视觉识别和数据分析技术&#xff0c;有效监控和管理河道上的采沙行为&#xff0c;对保护水域资源和改善生态环境具有显著的意义。 采沙船智…

Linux容器篇-使用kubeadm搭建一个kubernetes集群

kubernetes集群架构和组件 master节点组件 kube-apiserver&#xff1a;Kubernetes API&#xff0c;集群的统一入口&#xff0c;各组件的协调者&#xff0c;以RESTful API提供接口服务&#xff0c;所有对象资源的增删改查和监听操作都交给APIserver处理后再交给Etcd存储。 kube…

学习Mybatis

Mybatis 第一节 引言 1. 什么是框架 框架是一个半成品&#xff0c;解决了软件开发过程中的普遍性问题&#xff0c;简化了开发步骤&#xff0c;提高了开发效率。 2. 什么是ORM ORM全称为Object Relational Mapping&#xff0c;意为对象关系映射&#xff0c;主要实现了将程序…

usecallback()与usememo()

简单的说 都是用来监听数据变化 来进行控制渲染、减少不必要的渲染 、优化性能 usecallback()是用来监听数据变化从而调用方法 usememo()是用来监听数据变化从而改变数据 使用return返回变化的数据 当然return 也可以返回方法 所以usememo()可以代替usecallback() 下面详解 …

常见的编码技术简介

常见的编码技术简介 文章目录 常见的编码技术简介1. 字符编码1.1 ASCII1.2 Unicode 2. 数据传输编码2.1 Base系列编码2.1.1 Base642.1.2 Base162.1.3 Base322.1.4 Base852.1.5 其他Base编码 2.2 URL编码2.3 JSON2.4 XML2.5 Protobuf (Protocol Buffers) 1. 字符编码 1.1 ASCII…

AI是在帮助开发者还是取代他们?——探讨AI在软件开发中的角色与未来

引言 随着人工智能技术的迅猛发展&#xff0c;AI工具在软件开发中的应用越来越广泛。有人认为AI可以显著提升开发者的效率&#xff0c;而也有人担心AI会取代开发者的工作。本文将从三个方面探讨AI在软件开发中的角色&#xff1a;AI工具现状、AI对开发者的影响以及AI开发的未来…

学习springAOP

第三章 Spring AOP 第一节 AOP 简介 1. 概念 AOP全称为Aspect Oriented Programming&#xff0c;表示面向切面编程。何为切面呢&#xff1f; 由此可以得出&#xff0c;切面是一种将那些与业务无关&#xff0c;但业务模块都需要使用的功能封装起来的技术。这样便于减少系统的…

昇思25天学习打卡营第4天|应用实践

昇思25天学习打卡营第4天 文章目录 昇思25天学习打卡营第4天基于 MindSpore 实现 BERT 对话情绪识别模型简介环境配置数据集数据加载和数据预处理input_idsattention_mask 模型构建模型验证模型推理自定义推理数据集 打卡记录 基于 MindSpore 实现 BERT 对话情绪识别 模型简介…

奥比中光astra_pro相机使用记录

一、信息获取 1、官网 用于了解产品信息 http://www.orbbec.com.cn/sys/37.html 2、开发者社区 咨询问题下载开发部https://developer.orbbec.com.cn/ 二 、windowvs19 1、相机型号 orbbec_astro_pro 根据对应的型号找到需要的包工具 踩坑1&#xff0c;因为这个相机型号…

第20章 Mac+VSCode配置C++环境

1. 下载VSCode VSCode下载地址在mac终端里输入xcode- select --install命令&#xff0c;根据提示安装xcode工具。 2. 安装插件&#xff08;4个&#xff09; 打开VScode&#xff0c;点击应用右侧菜单栏 C/C&#xff08;必装&#xff09; Code Runner&#xff08;必装&#xf…

UCOS-III 任务调度与就绪列表管理

01. 就绪优先级位图 在实时操作系统中&#xff0c;任务调度的效率至关重要。UCOS-III通过就绪优先级位图来快速查找最高优先级的就绪任务&#xff0c;从而实现高效调度。就绪优先级位图是一个按位表示的结构&#xff0c;每个位代表一个优先级&#xff0c;当某个优先级上有任务就…