一个另类的数据库-Redis

今天小编来分享一下什么是Redis

简介:

什么是 Redis?

Redis(Remote Dictionary Server) 是一个开源的、基于内存的高性能键值(Key-Value)数据库。它支持多种数据结构,如字符串(String)、哈希(Hash)、列表(List)、集合(Set)、有序集合(Sorted Set)等,因此被广泛应用于缓存、消息队列、会话存储、排行榜、实时分析等场景。

Redis 的核心特点包括:

  • 内存存储:数据主要保存在内存中,读写速度极快(通常可达每秒数十万次操作)。

  • 持久化支持:虽然基于内存,但 Redis 提供了 RDB(快照)和 AOF(追加日志)两种持久化机制,可以在重启后恢复数据。

  • 丰富的数据类型:不仅支持简单的字符串,还支持复杂的数据结构,极大提升了开发灵活性。

  • 高可用与分布式:通过主从复制、哨兵(Sentinel)和 Redis Cluster 实现高可用性和横向扩展。

  • 原子性操作:所有 Redis 命令都是原子性的,支持事务(MULTI/EXEC)。

  • 单线程模型(6.0 之前):早期版本使用单线程处理命令,避免了锁竞争;Redis 6.0 引入了多线程 I/O,提升网络吞吐能力,但命令执行仍为单线程。

在主流 Linux 系统上下载并配置 Redis

Redis的下载一般是用于Linux的服务器上,所以接下来介绍下,常见的Linux发行版下载Redis

Redis 可在几乎所有主流 Linux 系统上运行,包括但不限于:

  • Ubuntu / Debian

  • CentOS / Rocky Linux / AlmaLinux

  • Fedora

  • openSUSE

2.2 安装方式(以 Ubuntu 和 CentOS 为例)

方法一:通过包管理器安装(推荐用于快速体验)

Ubuntu/ Debian

复制代码
sudo apt update sudo apt install redis-server

CentOS /Rocky Linux(需启用 EPEL 仓库):

复制代码
sudo dnf install epel-release -y sudo dnf install redis -y

注意:包管理器安装的 Redis 版本可能不是最新版,适合生产环境稳定需求,但若需新特性建议源码编译。


方法二:从源码编译安装(推荐用于生产或需要最新版本)
  1. 安装依赖

    Ubuntu/Debian sudo apt update sudo apt install build-essential tcl wget -y

    CentOS/Rocky sudo dnf groupinstall "Development Tools" -y sudo dnf install tcl wget -y

  2. 下载 Redis 源码 (以最新稳定版为例)

    cd /tmp wget https://download.redis.io/redis-stable.tar.gz tar -xzf redis-stable.tar.gz cd redis-stable

  3. 编译并安装

    make sudo make install

  4. 默认会将可执行文件(如 redis-server, redis-cli)安装到 /usr/local/bin/

  5. (可选)设置系统服务 Redis 源码包提供了 systemd 服务模板:

    sudo cp utils/redis_init_script /etc/init.d/redis_6379
    sudo mkdir /etc/redis sudo cp redis.conf /etc/redis/6379.conf

  6. 然后根据需要编辑配置文件并启动服务(详见下文配置部分)。


2.3 是否需要配置?如何配置?

是的,强烈建议进行基本配置,尤其是在生产环境中。

Redis 的主配置文件是 redis.conf。关键配置项包括:

|------------------|--------------|------------------------------------------|
| 配置项 | 说明 | 建议值(生产环境) |
| bind | 绑定 IP 地址 | 0.0.0.0(允许远程访问)或内网 IP(更安全) |
| protected-mode | 保护模式 | no(如果设置了密码或绑定了可信 IP) |
| port | 监听端口 | 默认 6379,可修改 |
| daemonize | 是否后台运行 | yes |
| requirepass | 设置访问密码 | 强密码(如 requirepass your_strong_password) |
| maxmemory | 最大内存限制 | 根据服务器资源设置(如 2gb) |
| maxmemory-policy | 内存淘汰策略 | allkeys-lru 或 volatile-lru |
| appendonly | 是否开启 AOF 持久化 | yes(更安全) |
| save | RDB 快照策略 | 根据业务调整,如 save 900 1 表示 900 秒内至少 1 次修改则保存 |

示例:最小安全配置(/etc/redis/redis.conf)
复制代码
复制代码
bind 0.0.0.0
protected-mode no
port 6379
daemonize yes
requirepass YourStrongPassword123!
maxmemory 2gb
maxmemory-policy allkeys-lru
appendonly yes
启动 Redis
复制代码
redis-server /etc/redis/redis.conf
测试连接
复制代码
redis-cli -a YourStrongPassword123! 
127.0.0.1:6379> ping 
PONG

小贴士

  • 不要在 公网 暴露 Redis 无密码 端口!极易被攻击(如数据清空、植入挖矿程序)。

  • 使用防火墙(如 ufwfirewalld)限制访问来源。

  • 定期备份 RDB/AOF 文件。

  • 监控内存使用和连接数。

相关推荐
RInk7oBjo2 小时前
spring-事务管理
数据库·sql·spring
希望永不加班2 小时前
SpringBoot 数据库连接池配置(HikariCP)最佳实践
java·数据库·spring boot·后端·spring
黑牛儿3 小时前
MySQL 索引实战详解:从创建到优化,彻底解决查询慢问题
服务器·数据库·后端·mysql
捧月华如3 小时前
RAG 入门-向量存储与企业级向量数据库 milvus
数据库·milvus
杨云龙UP3 小时前
Oracle Data Pump实战:expdp/impdp常用参数与导入导出命令整理_20260406
linux·运维·服务器·数据库·oracle
想唱rap4 小时前
线程池以及读写问题
服务器·数据库·c++·mysql·ubuntu
一个有温度的技术博主4 小时前
Redis AOF持久化:用“记账”的方式守护数据安全
redis·分布式·缓存
RATi GORI4 小时前
springBoot连接远程Redis连接失败(已解决)
spring boot·redis·后端
爱丽_4 小时前
B+ 树范围查询为什么快:页分裂/合并、索引设计与 SQL 写法优化
数据库·算法·哈希算法