Redis基础入门实践详解

本文涉及的产品
云数据库 Redis 版,社区版 2GB
推荐场景:
搭建游戏排行榜
简介: Redis基础入门实践详解

Redis:Remote DIctionary Server(远程字典服务器)。是完全开源免费的,用C语言编写的,遵守BSD协议,是一个高性能的(key/value)分布式内存数据库,基于内存运行并支持持久化的NoSQL数据库,是当前最热门的NoSql数据库之一,也被人们称为数据结构服务器。


开源界的 5 大许可协议:五大开源许可协议分别是GPL,LGPL,BSD,MIT,Apache。


三个特点:

  • Redis支持数据的持久化,可以将内存中的数据保持在磁盘中,重启的时候可以再次加载进行使用。
  • Redis不仅仅支持简单的key-value类型的数据,同时还提供list,set,zset,hash等数据结构的存储。
  • Redis支持数据的备份,即master-slave模式的数据备份。


【1】单进程

Redis是以单进程模型为处理客户端的请求。对读写等事件的响应是通过对epoll函数的包装来做到的。


Redis的实际处理速度完全依靠主进程的执行效率。

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



【2】默认16个DB

查看conf配置文件如下:

上图说明,默认共有16个数据库,连接默认使用第一个数据库(db[0])。

可以使用如下命令切换数据库使用:

select index
//如select 1


aHR0cDovL2ltZy5ibG9nLmNzZG4ubmV0LzIwMTcxMDMwMTAzMzMzOTc1.png

【3】查看当前数据库key的个数

命令格式如下:

DBSIZE


aHR0cDovL2ltZy5ibG9nLmNzZG4ubmV0LzIwMTcxMDMwMTAzNTQ1MDg3.png


【4】清空当前/全部库

  • 清空当前库
FLUSHDB
  • 清空全部库(慎用)
FLUSHALL



aHR0cDovL2ltZy5ibG9nLmNzZG4ubmV0LzIwMTcxMDMwMTAzODQzNzU3.png



【5】设置密码

Redis客户端连接默认是不需要密码的。

① 可以使用如下命令进行密码设置

config set requirepass [your password]


如下图所示,当设置密码之后,再次连接必须使用密码,否则提示无权限。


使用密码进行客户端连接:



也可以使用如下方式进行客户端连接:


② 修改conf配置文件

修改配置文件如下:



重启redis,使用①中设置的密码进行登录提示无权限。使用配置文件中设置的密码进行登录,成功。


注释掉配置文件中的密码设置,重启redis服务,再次进行客户端连接,无需使用密码。

即,使用命令配置只针对当前客户端游戏,服务重启,命令配置失效。


【6】Redis与数据库数据一致性

我们知道使用Redis作为缓存数据库时,一般会有时效性问题。如果数据库修改,则可能会造成缓存与数据库数据一致性问题,如果避免这个问题呢?


第一种情况


当Redis里面key失效了(不考虑永久key),则会穿透到数据库,从数据库获取值然后放入Redis,此时是不会有数据一致性问题的。


第二种情况


当要去修改数据库时就会出现Redis与数据库数据一致性问题。如何解决呢?比如说修改数据库后修改Redis里面的值,但是这里有一个问题,如果修改数据库成功了但是修改Redis失败了呢?


最好的办法是如果需要修改数据库里面值是先把Redis里面对应key 删除掉,然后修改数据库,这两步写在一个方法里。这样当另外请求过来时,因为Redis里面key没有了会直接穿透到数据库。

【7】Redis的启动与停止

① 启动

第一种方式:前端启动不指定配置文件

#bin目录下
./redis-server


第二种方式:修改redis.conf,把daemonize no修改成daemonize yes,启动时,指定配置文件

./redis-server  ../conf/redis.conf

第三种方式:编写服务脚本参考CentOS7 下源码安装Redis并配置服务开机启动

service start redis


② 停止

第一种方式:kill -9 pid 强制结束程序。

使用kill -9 进程的pid,强行终止Redis进程可能会导致redis持久化丢失。


第二种方式:向redis发送shutdown命令

./redis-cli shutdown


第三种方式:服务命令

service redis stop
相关实践学习
基于Redis实现在线游戏积分排行榜
本场景将介绍如何基于Redis数据库实现在线游戏中的游戏玩家积分排行榜功能。
云数据库 Redis 版使用教程
云数据库Redis版是兼容Redis协议标准的、提供持久化的内存数据库服务,基于高可靠双机热备架构及可无缝扩展的集群架构,满足高读写性能场景及容量需弹性变配的业务需求。 产品详情:https://www.aliyun.com/product/kvstore     ------------------------------------------------------------------------- 阿里云数据库体验:数据库上云实战 开发者云会免费提供一台带自建MySQL的源数据库 ECS 实例和一台目标数据库 RDS实例。跟着指引,您可以一步步实现将ECS自建数据库迁移到目标数据库RDS。 点击下方链接,领取免费ECS&RDS资源,30分钟完成数据库上云实战!https://developer.aliyun.com/adc/scenario/51eefbd1894e42f6bb9acacadd3f9121?spm=a2c6h.13788135.J_3257954370.9.4ba85f24utseFl
目录
相关文章
|
2月前
|
存储 缓存 NoSQL
蚂蚁金服P7私藏的Redis原理与实践内部笔记
Redis 是完全开源免费的,是一个高性能的key-value类型的内存数据库。整个数据库统统加载在内存当中进行操作,定期通过异步操作把数据库数据flush到硬盘上进行保存。因为是纯内存操作,Redis的性能非常出色,每秒可以处理超过 10万次读写操作,是已知性能最快的Key-Value DB。
61 1
|
3月前
|
NoSQL 中间件 API
分布式锁【数据库乐观锁实现的分布式锁、Zookeeper分布式锁原理、Redis实现的分布式锁】(三)-全面详解(学习总结---从入门到深化)(下)
分布式锁【数据库乐观锁实现的分布式锁、Zookeeper分布式锁原理、Redis实现的分布式锁】(三)-全面详解(学习总结---从入门到深化)
82 2
|
3月前
|
NoSQL Java API
分布式锁【数据库乐观锁实现的分布式锁、Zookeeper分布式锁原理、Redis实现的分布式锁】(三)-全面详解(学习总结---从入门到深化)(上)
分布式锁【数据库乐观锁实现的分布式锁、Zookeeper分布式锁原理、Redis实现的分布式锁】(三)-全面详解(学习总结---从入门到深化)
74 0
|
2天前
|
存储 NoSQL Linux
Redis入门到通关之Redis5种网络模型详解
Redis入门到通关之Redis5种网络模型详解
10 1
|
2天前
|
存储 NoSQL 算法
Redis入门到通关之Redis数据结构-Hash篇
Redis入门到通关之Redis数据结构-Hash篇
12 1
|
2天前
|
存储 NoSQL Redis
Redis入门到通关之Redis数据结构-List篇
Redis入门到通关之Redis数据结构-List篇
|
2天前
|
存储 NoSQL 安全
Redis入门到通关之Redis数据结构-String篇
Redis入门到通关之Redis数据结构-String篇
|
2天前
|
存储 NoSQL Redis
Redis入门到通关之数据结构解析-SkipList
Redis入门到通关之数据结构解析-SkipList
|
2天前
|
存储 NoSQL 安全
Redis入门到通关之数据结构解析-动态字符串SDS
Redis入门到通关之数据结构解析-动态字符串SDS
10 0
|
2天前
|
NoSQL Redis
Redis入门到通关之Redis主从数据同步原理
Redis入门到通关之Redis主从数据同步原理

热门文章

最新文章