Redis入门

Redis是一款开源的Key-Value数据库,提供多种数据结构并支持事务、持久化。文章详细介绍了Redis的安装过程,包括环境配置、编译安装、配置启动,并提到了其作为NoSql数据库的特点。此外,还提及了如何连接图形化工具进行管理。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

一、Redis是什么

1、官方定义

Remote Dictionary Server(远程字典服务)是完全开源的,使用ANSIC语言编写遵守BSD协议,是一个高性能的Key-Value数据库提供了丰富的数据结构,例如String、Hash、List、Set、SortedSet等等。数据是存在内存中的,同时Redis支持事务、持久化、LUA脚本、发布/订阅、缓存淘汰、流技术等多种功能特性提供了主从模式、Redis Sentinel和Redis Cluster集群架构方案。

2、NoSql

Redis是一种键值型的NoSql数据库

数据库Not Only Sql(不仅仅是SQL),或者是No Sql(非Sql的)数据库。是相对于传统关系型数据库而言,有很大差异的一种特殊的数据库,因此也称之为非关系型数据库

①键值型存储数据库:Redis中存储的数据是以key.value对的形式存储,value的形式多种多样,可以是字符串、数值、json。

②文档型存储数据库:NoSQL 与关系型数据的结合,最像关系型数据库的 NoSQL

 ③图形(Graph)数据库:用于存放一个节点关系的数据库

二、Redis的安装

1、安装redis需要的C语言环境

yum install -y gcc tcl

2、上传压缩包

/usr/local/src

如果不能上传,需要给这个包权限  chmod 777 /usr/local/src

 3、解压缩

tar -zxvf redis-7.2-rc2.tar.gz

4、进入redis 

cd redis-7.2-rc2

5、运行编译

make && make install

6、指定配置启动 

进入redis安装目录,修改Redis配置文件redis.conf,并且先进行备份

cp redis.conf redis.conf.bak

修改redis.conf文件的配置

# 允许访问的地址,默认是127.0.0.1,会导致只能在本地访问。修改为0.0.0.0则可以在任意IP访问,生产环境不要设置为0.0.0.0
bind 0.0.0.0
# 守护进程,修改为yes后即可后台运行
daemonize yes 
# 密码,设置后访问Redis必须输入密码
requirepass 123456

# 进入redis安装目录 
cd /usr/local/src/redis-7.2-rc2
# 启动
redis-server redis.conf

# 利用redis-cli来执行 shutdown 命令,即可停止 Redis 服务,
# 因为之前配置了密码,因此需要通过 -u 来指定密码
redis-cli -u 123456 shutdown

//默认端口时6379

7、开启redis

启动redis服务

redis-server redis.conf

redis-cli -a 123456

先进行ping命令

如果显示pong成功进入

8、连接图形化工具

<think>好的,我现在需要帮助用户学习Redis的基础知识,包括入门教程、基础概念以及学习资料。首先,我应该整理用户提供的引用内容,看看里面有哪些有用的信息。 根据引用[1],Redis是2009年诞生的,全称是Remote Dictionary Server,基于内存的键值型NoSQL数据库。这一点很重要,是Redis的基本定义。接下来,引用[2]提到Jedis、Lettuce和Redisson这三个Java客户端,以及SpringDataRedis对他们的封装,还有Redisson的分布式数据结构。这可能对用户学习客户端工具有帮助。 引用[3]说明了Redis执行命令需要网络请求和响应延迟,这可能影响性能。引用[4]给出了启动Redis服务器的方法,特别是解决闪退的问题。引用[5]提到了持久化的配置,关闭RDB和AOF可以变成纯内存数据库,类似Memcached,还有事务处理。 用户需要入门教程、基础概念和学习资料。首先,我应该从基础概念开始,比如数据结构、持久化、事务、应用场景等。然后推荐学习路径,可能包括官方文档、书籍、视频教程等。还要注意引用中的内容,比如推荐的Java客户端,启动服务器的步骤,持久化的配置等。 需要确保回答结构清晰,分步骤介绍,并且引用相关的内容。例如,在讲基础概念时,提到键值存储和数据结构时引用[1],在讲Java客户端时引用[2],持久化部分引用[5]。同时,生成相关问题,帮助用户深入学习。 可能还需要检查是否有遗漏的重要概念,比如主从复制、哨兵、集群等,但根据引用内容,用户提供的资料里没有提到这些,所以可能需要简要提及,但重点放在引用提到的内容上。 最后,确保使用正确的中文表达,避免技术术语错误,并按照用户的格式要求,使用$...$和$$...$$来标记数学表达式,不过在这个问题中可能用不到数学公式,但需要遵守系统指令的其他要求,如引用标识的添加。</think>### Redis 基础知识入门指南 #### 一、基础概念 1. **核心定义** Redis(Remote Dictionary Server)是**基于内存的键值型NoSQL数据库**,支持字符串、哈希、列表等多种数据结构[^1]。其核心优势在于**高性能读写**(微秒级响应)和**分布式特性**。 2. **数据结构** 支持5种基础类型: - 字符串(String) - 哈希(Hash) - 列表(List) - 集合(Set) - 有序集合(ZSet) 额外支持流(Stream)、地理空间(GEO)等扩展类型。 3. **持久化机制** - **RDB**:定时生成内存快照 - **AOF**:记录所有写操作命令 可关闭持久化变为纯内存数据库(类似Memcached)[^5]。 4. **事务特性** 通过`MULTI`/`EXEC`命令实现简单事务,但**不保证原子性**(单条命令失败不影响后续执行)。 --- #### 二、学习路径与资源 1. **官方文档** [Redis官方文档](https://redis.io/docs/):权威指南,涵盖安装、配置、命令详解。 2. **快速入门教程** - **视频教程**:B站《20分钟搞定Redis基础》覆盖基础操作与客户端使用[^2] - **实践指南**: ```bash # 启动Redis服务器(Windows示例) redis-server.exe redis.windows.conf ``` 若遇到闪退问题可参考此方法[^4]。 3. **客户端工具** - **Java推荐**: - `Jedis`/`Lettuce`:直接操作Redis命令 - `SpringDataRedis`:对上述客户端的封装 - `Redisson`:实现分布式锁、队列等高级功能[^2] 4. **书籍推荐** - 《Redis设计与实现》:深入源码与设计原理 - 《Redis实战》:结合实际案例讲解应用 --- #### 三、应用场景 1. **缓存加速**:缓解数据库压力(如热点数据缓存) 2. **会话存储**:分布式系统共享Session 3. **排行榜**:通过ZSet实现实时排序 4. **消息队列**:使用List或Stream实现 --- #### 四、性能优化要点 1. **网络延迟**:批量操作(如`pipeline`)减少请求次数[^3] 2. **内存管理**:设置过期时间,避免内存溢出 3. **持久化选择**:根据业务需求平衡RDB与AOF ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

IsLuNaTiC

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

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

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

打赏作者

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

抵扣说明:

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

余额充值