五分钟了解Redis

发布时间:2020-07-21 15:00:33 作者:wx5d3fd1efe40e3
来源:网络 阅读:316

内容要点:

一、Redis 简介:

二、安装部署 Redis:

三、Redis 配置文件:

四、Redis 数据库常用命令:

五、Redis 持久化:

六、Redis 性能管理:

补充:

一、关系数据库(SQL)和非关系数据库(NoSQL)简要分析:

二、Redis 和 Memcache 的比较


一、Redis 简介:

二、安装部署 Redis:

(1)安装 redis:

安装包:redis-5.0.7.tar.gz

系统:Linux


操作步骤总览:

五分钟了解Redis


第一步:通过远程挂载的办法将 windows上的安装包下载到 Linux本地。


第二步:安装编译工具

 yum install gcc gcc-c++ make -y


第三步:解压


tar zxvf redis-5.0.7.tar.gz -C /opt/


第四步:安装


cd redis-5.0.7/
make
make PREFIX=/usr/local/redis install


第五步:创建软连接

ln -s /usr/local/redis/bin/* /usr/local/bin/


第五步:启动安装脚本,查看端口状态


cd  /redis-5.0.7/utils/

./install_server.sh  //启动脚本,注意:这步一路回车到底就行了

netstat -natp | grep 6379


除此之外,还可以用 redis_6379 控制其开启关闭:


/etc/init.d/redis_6379 stop       //关闭

/etc/init.d/redis_6379 start      //开启

/etc/init.d/redis_6379 restart    //重启


(2)redis-cli 远程连接:

1、先修改配置文件,添加主机的IP地址


vim /etc/redis/6379.conf

bind 127.0.0.1 192.168.220.131
//添加主机的IP地址


2、重启服务


3、远程连接


redis-cli -h 192.168.220.131 -p 6379
//-h:指定主机IP地址,-p:指定端口



三、Redis 配置文件:

配置参数
vim /etc/redis/6379.conf
bind:监听的主机地址
port:端口
daemonize yes:启用守护进程
pidfile:指定PID文件
loglevel notice:日志级别
logfile:指定日志文件



四、Redis 数据库常用命令:

(一)常用命令:

(1)redis-cli 命令行工具:


1、连接本地数据库:

/usr/local/redis/bin/redis-cli



2、连接远程数据库:

redis-cli -h 192.168.220.131 -p 6379


3、存放数据(set):

五分钟了解Redis

4、获取数据(get):

五分钟了解Redis


(2)key 相关命令:


1、keys :获取符合规则的键值列表


>keys *        //查看当前数据库中所有的键

>keys v*       //查看当前数据库中以v开头的键

>keys v?       //查看当前数据库中以v开头后面包含任意一个字符的键

>keys v??      //查看当前数据库中以v开头后面包含任意二个字符的键


2、exists:判断键值是否存在

五分钟了解Redis

3、del :删除当前数据库的指定 key

五分钟了解Redis

4、type :获取 key 对应的 value 值类型

五分钟了解Redis

5、rename(覆盖)/ renamenx(不覆盖):对已有的 key 进行重命名:

五分钟了解Redis

6、dbsize :查看当前数据库中 key 的数目

五分钟了解Redis

(3)redis-benchmark 测试工具:

-h:指定服务器主机名
-p:指定服务器端口
-c:指定并发连接数
-n: 指定请求数
-d:以字节的形式指定SET/GET值的数据大小
-q:强制推出redis。仅显示query/sec值


redis-benchmark -h 192.168.220.131 -p 6379 -c 100 -n 100000
//向IP地址为192.168.220.131、端口为6379的redis服务器发送 100个并发连接与 100000个请求测试性能


redis-benchmark -h 192.168.220.131 -p 6379 -q -d 100
//测试存取大小为100字节的数据包的性能


(二)Redis 多数据操作:

(1)Redis 支持多数据库,默认支持16个数据库,0-15 命名;


(2)多数据相互独立,互不干扰;


(3)多数据常用命令;


1、select:多数据库间的切换(默认是在数据库0中)

五分钟了解Redis

2、move:多数据库间移动数据

五分钟了解Redis

3、flushdb:清除数据库内数据

五分钟了解Redis


五、Redis 持久化:

(1)持久化概述:

(2)持久化分类:

1、RDB 方式:创建快照的方式获取某一时刻 Redis 中所有数据的副本。


2、AOF 方式:将执行的写命令写到文件的末尾,以日志的方式来记录数据的变化。


(3)RDB持久化:

1、它是 Redis的默认持久化方式,默认文件名为 dump.rdb


2、触发条件:


3、优缺点:


4、通过 RDB 文件恢复数据:


5、配置文件选项:


vim /etc/redis/6379.conf


save 900 1              
save 300 10
save 60 10000
//900秒之内至少一次写操作、300秒之内至少发生10次写操作、60秒之内发生至少10000次写操作,只要满足其一都会触发快照操作,注释所有的save项表示关闭 RDB

dbfilename dump.rdb         // RDB文件名称
dir /var/lib/redis/6379     // RDB文件路径
rdbcompression yes          // 是否进行压缩


(4)AOF 持久化:

1、根据 AOF 文件恢复数据:

2、配置文件选项:


vim /etc/redis/6379.conf

appendonly yes                     //开启AOF持久化
appendfilename "appendonly.aof"    //AOF文件名称
appendfsync always    
appendfsync everysec
appendfsync no
//解释:always:同步持久化,每次发生数据变化会立刻写入磁盘;
       everysec:默认推荐,每秒异步记录一次(默认值);
       no:不同步,交给操作系统决定如何同步。

       aof-load-truncated yes         //忽略最后一条可能存在问题的指令



3、AOF 的重写机制:


4、AOF 的重写原理:


5、AOF 的重写配置:


vim /etc/redis/6379.conf

在日志进行 BGREWRITEAOF 时,如果设置为 yes 表示新写操作不进行同步 fsync,只是暂存在缓冲区里,避免造成磁盘 IO 操作冲突,等重写完成后在写入。redis 中默认为 no
no-appendfsync-on-rewrite no

//当前 AOF文件大小是上次日志重写时 AOF 文件大小两倍时,发生 BGREWRITEAOF操作
auto-aof-rewrite-percentage 100

//当前 AOF文件执行 BGREWRITEAOF命令的最小值,避免刚开始启动 redis 时由于文件尺寸较小导致频繁的 BGREWRITEAOF
auto-aof-rewrite-min-szie 64mb


六、Redis 性能管理:

(1)内存碎片率:

1、操作系统分配的内存值 used_memory_rss 除以 redis 使用的内存值 used_memory 计算得出的;


2、内存碎片是由操作系统低效的分配/回收物理内存导致的;


3、跟踪内存碎片率对理解 redis 实例的资源性能是非常重要的;


五分钟了解Redis


五分钟了解Redis

(2)内存使用率:

1、 redis 实例的内存使用率超过可用最大内存,操作系统开始进行内存与 swqp 空间交换;


2、避免内存交换:


(3)回收 Key:

1、保证合理分配 redis 有限的内存资源;


2、当内存使用达到设置的最大阈值时,需要选择一种 key 的回收策略:


--volatile-lru:使用L .RU算法从已设置过期时间的数据集合中淘汰数据
--voltil-tt:从已设置过期时间的数据集合中挑选即将过期的数据淘汰
--volatile-random:从已设置过期时间的数据集合中随机挑选数据淘汰
--allkeys-lru:使用LRU算法从所有数据集合中淘汰数据
--allkeys-random:从数据集合中任意选择数据淘汰
--no-enviction:禁止淘汰数据



补充:

一、关系数据库(SQL)和非关系数据库(NoSQL)简要介绍:

(1)关系型数据库(SQL):

1、一个结构化的数据库,创建在关系模型基础上,一般面向于记录;


2、包括 Oracle 、Mysql 、 SQL Server 、Microsoft Access 、DB2 等。


优点:

1、易于维护:都是使用表结构,格式一致;

2、使用方便:SQL语言通用,可用于复杂查询;

3、复杂操作:支持SQL,可用于一个表以及多个表之间非常复杂的查询。


缺点:


1、读写性能比较差,尤其是海量数据的高效率读写;

2、固定的表结构,灵活度稍欠;

3、对于高并发读写需求,传统关系型数据库来说,硬盘I/O是一个很大的瓶颈。


(2)非关系型数据库(NoSQL):

1、除了主流的关系型数据库以外的数据库,都认为是非关系型的;

2、包括 Redis 、 MongBD 、 Hbase 、 CouhDB 、Memcache 等;

3、非关系型数据库严格上不是一种数据库,应该是一种数据结构化存储方法的集合,可以是文档或者键值对等。


优点:


1、格式灵活:存储数据的格式可以是 key-value(键-值)形式、文档形式、图片形式等等,文档形式、图片形式等等,使用灵活,应用场景广泛,而关系型数据库则只支持基础类型;

2、速度快:nosql可以使用硬盘或者随机存储器作为载体,而关系型数据库只能使用硬盘;

3、高扩展性;

4、成本低:nosql数据库部署简单,基本都是开源软件。


缺点:


1、不提供sql支持,学习和使用成本较高;

2、不支持事务,容错率低;

3、数据结构相对复杂,复杂查询方面稍欠。


(3)非关系型数据库产生的背景:

High performance :对数据库高并发读写需求;

Huge Storage:对海量数据高效存储与访问需求;

High Scalability && High Availability:对数据库高可扩展性与高可用性需求。

如本文主角redis便为非关系型数据库。


二、Redis 和 Memcache 的比较:


1、存储方式:


Memecache把数据全部存在内存之中,断电后会挂掉,数据不能超过内存大小;


Redis有部份存在硬盘上,这样能保证数据的持久性。


2、数据支持类型:


Memcache对数据类型支持相对简单;


Redis有复杂的数据类型。


3、使用底层模型不同:


它们之间底层实现方式以及与客户端之间通信的应用协议不一样;


Redis直接自己构建了VM 机制 ,因为一般的系统调用系统函数的话,会浪费一定的时间去移动和请求。


4、value大小:


redis最大可以达到1GB,而memcache只有1MB。


5、使用redis有哪些好处?


1、速度快,因为数据存在内存中,类似于HashMap,HashMap的优势就是查找和操作的时间复杂度都是O(1)


2、支持丰富数据类型,支持string,list,set,sorted set,hash


3、支持事务,操作都是原子性,所谓的原子性就是对数据的更改要么全部执行,要么全部不执行。


4、丰富的特性:可用于缓存,消息,按key设置过期时间,过期后将会自动删除。


redis 相比 memcached 的优势:



推荐阅读:
  1. 了解Linux
  2. 了解DataTables

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

redis 关系型数据库与非关系型数据库 edi %d

上一篇:Flutter如何使用Navigator进行局部跳转页面

下一篇:python求100以内素数的实现方法

相关阅读

您好,登录后才能下订单哦!

密码登录
登录注册
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》