首页 数据库 Redis 小记 Redis介绍与安装部署

小记 Redis介绍与安装部署

Feb 24, 2021 am 09:52 AM
redis

小记 Redis介绍与安装部署

推荐(免费):redis

文章目录

  • 一、Redis是什么
  • 二、Redis能干什么
  • 三、Redis下载与安装部署
  • 四、Redis的几个小知识

一、Redis是什么

Redis:REmote DIctionary Server(远程字典服务器)

Redis是完全开源免费的,用C语言编写的,遵守BSD协议的一个高性能的(key/value)分布式内存数据库,也是基于内存运行并支持持久化的NoSQL数据库,是当前最热门的NoSql数据库之一,也被人们称为数据结构服务器。同时,Redis也是一个简单的、高效的、分布式的、基于内存的缓存工具。架构好服务器后,通过网络连接(类似数据库),提供Key-Value式缓存服务。

Redis有以下几个优势:

  • 1.性能极高 Redis读的速度是11万次/s,写的速度是8万次/秒。
  • 2.丰富的数据类型 Redis支持的类型有String、Hash、List、Set以及Ordered Set数据库类型。
  • 3.原子性 Redis所有操作都是原子性的,通过MULTI和EXEC指令包起来。
  • 4.丰富的读写 Redis支持publish/subscribe、通知、key过期等特性。
  • 5.高速读写 redis使用自己实现的分离器,代码量很短,没有使用lock(MySQL),因此效率非常高。

Redis也有以下几个劣势:

  • 1.持久化 Redis直接将数据存储在内存中,如果要将数据保存到磁盘上,第一种方法是使用①定时快照(snapshot):每隔一段时间将整个数据库写到磁盘上,每次均是写全部数据,但是代价非常高;第二种方法是②基于语句追加(aof):只追踪变化的数据,但是追加的log可能过大,同时所有的操作均重新执行一遍,恢复速度慢。
  • 2.耗内存,占用内存过高。

二、Redis能干什么

企业开发中,可以将Redis作为数据库、缓存、热点数据(经常被查询但是不被修改和删除的数据)、消息中间件等大部分功能。

Redis的常用场景实例如下:

  • 缓存
    如今缓存几乎是所有中大型网站都在用的必杀技,合理的利用缓存不仅能够提升网站的访问速度,还能大大降低数据库的压力。Redis提供了键过期的功能,也提供了灵活的键淘汰策略。

  • 排行榜
    如淘宝的月度销量榜单、商品按时间的上新排行榜等。Redis提供的有序集合数据类构能实现各种复杂的排行榜应用。

  • 计数器
    如电商网站商品的浏览量、视频网站视频的播放数等。为了保证数据实时效,每次浏览都得给+1,并发量高时如果每次都请求数据库操作无疑是种挑战和压力。Redis提供的incr命令来实现计数器功能,内存操作,性能非常好,非常适用于这些计数场景。

  • 分布式会话
    集群模式下,在应用不多的情况下一般使用容器自带的session复制功能就能满足,在应用增多相对复杂的系统中,一般都会搭建以Redis等内存数据库为中心的session服务,session不再由容器管理,而是由session服务及内存数据库管理。

  • 分布式锁
    分布式技术带来的技术挑战是对同一个资源的并发访问,如全局ID、减库存、秒杀等场景,并发量不大的场景可以使用数据库的悲观锁、乐观锁来实现,但在并发量高的场合中,利用数据库锁来控制资源的并发访问是不太理想的,大大影响了数据库的性能。可以利用Redis的setnx功能来编写分布式的锁,如果设置返回1说明获取锁成功,否则获取锁失败,实际应用中要考虑的细节要更多。

  • 社交网络
    点赞、踩、关注/被关注、共同好友等是社交网站的基本功能,社交网站的访问量通常来说比较大,而且传统的关系数据库类型不适合存储这种类型的数据,Redis提供的哈希、集合等数据结构能很方便的的实现这些功能。

  • 最新列表
    Redis列表结构,LPUSH可以在列表头部插入一个内容ID作为关键字,LTRIM可用来限制列表的数量,这样列表永远为N个ID,无需查询最新的列表,直接根据ID去到对应的内容页即可。

  • 消息系统
    消息队列是大型网站必用中间件,如ActiveMQ、RabbitMQ、Kafka等流行的消息队列中间件,主要用于业务解耦、流量削峰及异步处理实时性低的业务。Redis提供了发布/订阅及阻塞队列功能,能实现一个简单的消息队列系统。但是,这个不能和专业的消息中间件相比。

三、Redis下载与安装部署

Redis英文官网。
Redis中文网站。

由于企业里面做Redis开发,99%都是Linux版的运用和安装,所以本文仅介绍Linux下的安装与运行,Windows下的安装使用小伙伴们可以自行百度。前往上面的官网点击Download下载.gz安装包后,放在Linux下的/opt目录 (我这里安装的是Redis的6.0.5版本)。

  • 解压命令为:tar -zxvf redis-6.0.5.tar.gz

上述命令只是解压了Redis,如果想要安装Redis,需要Linux系统有gcc环境,如果没有可以使用yum install gcc-c++安装,然后使用gcc -v查看版本。

如果Linux环境已经有了gcc环境,直接使用下面的命令进行安装:

  • 安装命令为:make install

安装好默认是像Tomcat那样不能开机自启的,可以修改 redis.conf 文件中的 daemonize 属性为yes。

  • 开启redis服务:redis-server /myredis/redis.conf(此处为修改属性后的redis配置文件)

查看后台Redis服务是否启动:

  • ps -ef|grep redis

开启Redis服务:

  • redis-cli -p 6379
    在这里插入图片描述

正常关闭,数据会进行保存
在redis命令行中使用shutdown命令关闭。

非正常关闭,易导致数据丢失
断电、手动kill掉redis进程等。

几个其他的redis命令
在这里插入图片描述

四、Redis的几个小知识

Redis是一个单进程,使用单进程模型来处理客户端的请求。对读写等事件的响应是通过对epoll函数的包装来做到的。Redis的实际处理速度完全依靠主进程的执行效率。

epoll是Linux内核为处理大批量文件描述符而作了改进的epoll,是Linux下多路复用IO接口select/poll的增强版本,它能显著提高程序在大量并发连接中只有少量活跃的情况下的系统CPU利用率。

  • Redis默认有16个数据库,下标从零开始,初始默认使用零号库,可以使用SELECT <dbid>命令连接上指定数据库。
    在这里插入图片描述

  • dbsize指令可以查看当前数据库的key的数量,keys *查看所有的key。
    在这里插入图片描述

  • flushdb:清空当前库(慎用)

  • Flushall:清空全部库(慎用)

  • 统一密码管理,16个库都是同样密码,要么都OK要么一个也连接不上。

  • Redis索引都是从零开始

  • Redis默认端口是6379

更多相关免费学习推荐:redis入门教程

以上是小记 Redis介绍与安装部署的详细内容。更多信息请关注PHP中文网其他相关文章!

本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

Video Face Swap

Video Face Swap

使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热工具

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

redis集群模式怎么搭建 redis集群模式怎么搭建 Apr 10, 2025 pm 10:15 PM

Redis集群模式通过分片将Redis实例部署到多个服务器,提高可扩展性和可用性。搭建步骤如下:创建奇数个Redis实例,端口不同;创建3个sentinel实例,监控Redis实例并进行故障转移;配置sentinel配置文件,添加监控Redis实例信息和故障转移设置;配置Redis实例配置文件,启用集群模式并指定集群信息文件路径;创建nodes.conf文件,包含各Redis实例的信息;启动集群,执行create命令创建集群并指定副本数量;登录集群执行CLUSTER INFO命令验证集群状态;使

redis数据怎么清空 redis数据怎么清空 Apr 10, 2025 pm 10:06 PM

如何清空 Redis 数据:使用 FLUSHALL 命令清除所有键值。使用 FLUSHDB 命令清除当前选定数据库的键值。使用 SELECT 切换数据库,再使用 FLUSHDB 清除多个数据库。使用 DEL 命令删除特定键。使用 redis-cli 工具清空数据。

redis怎么读取队列 redis怎么读取队列 Apr 10, 2025 pm 10:12 PM

要从 Redis 读取队列,需要获取队列名称、使用 LPOP 命令读取元素,并处理空队列。具体步骤如下:获取队列名称:以 "queue:" 前缀命名,如 "queue:my-queue"。使用 LPOP 命令:从队列头部弹出元素并返回其值,如 LPOP queue:my-queue。处理空队列:如果队列为空,LPOP 返回 nil,可先检查队列是否存在再读取元素。

redis指令怎么用 redis指令怎么用 Apr 10, 2025 pm 08:45 PM

使用 Redis 指令需要以下步骤:打开 Redis 客户端。输入指令(动词 键 值)。提供所需参数(因指令而异)。按 Enter 执行指令。Redis 返回响应,指示操作结果(通常为 OK 或 -ERR)。

redis怎么使用锁 redis怎么使用锁 Apr 10, 2025 pm 08:39 PM

使用Redis进行锁操作需要通过SETNX命令获取锁,然后使用EXPIRE命令设置过期时间。具体步骤为:(1) 使用SETNX命令尝试设置一个键值对;(2) 使用EXPIRE命令为锁设置过期时间;(3) 当不再需要锁时,使用DEL命令删除该锁。

redis怎么读源码 redis怎么读源码 Apr 10, 2025 pm 08:27 PM

理解 Redis 源码的最佳方法是逐步进行:熟悉 Redis 基础知识。选择一个特定的模块或功能作为起点。从模块或功能的入口点开始,逐行查看代码。通过函数调用链查看代码。熟悉 Redis 使用的底层数据结构。识别 Redis 使用的算法。

redis命令行怎么用 redis命令行怎么用 Apr 10, 2025 pm 10:18 PM

使用 Redis 命令行工具 (redis-cli) 可通过以下步骤管理和操作 Redis:连接到服务器,指定地址和端口。使用命令名称和参数向服务器发送命令。使用 HELP 命令查看特定命令的帮助信息。使用 QUIT 命令退出命令行工具。

centos redis如何配置Lua脚本执行时间 centos redis如何配置Lua脚本执行时间 Apr 14, 2025 pm 02:12 PM

在CentOS系统上,您可以通过修改Redis配置文件或使用Redis命令来限制Lua脚本的执行时间,从而防止恶意脚本占用过多资源。方法一:修改Redis配置文件定位Redis配置文件:Redis配置文件通常位于/etc/redis/redis.conf。编辑配置文件:使用文本编辑器(例如vi或nano)打开配置文件:sudovi/etc/redis/redis.conf设置Lua脚本执行时间限制:在配置文件中添加或修改以下行,设置Lua脚本的最大执行时间(单位:毫秒)

See all articles