用户对App后台的响应速度要求越来越高。把数据存储在硬盘上,由于受到硬盘读写速度的限制,因此数据读写的速度有限。内存比硬盘的读写速度高了个数量级,因此基于内存的数据读取电比硬盘提高了个数量级,而Redis正是基于内存存储数据,保证了数据快速的读写速度。同时Redis提供了丰富的数据类型(string. hash、list. set及zset),给APP开发者带来了很大的便利。深圳APP开发公司今天主要介绍Redis下面的内容。
·Redis的功能简介
·常用数据结构及应用场景
·内存优化
·集群
·持久化
·故障排除案例
APP制作关于Redis简介
MvSQL被广泛用于数据存储,但MySQL读写速度慢,随着移动互联网的发展.越来越多的业务场景需要满足下面的需求。
·少量数据需要被经常读写,同时对读写速度要求非常高。
·能提供丰富的数据结构。
·提供数据落地的功能。
APP制作如表7-1所示展示了计算机中主要存储介质的访问速度
我们在表7-1中可了解,从内存中顺序读取1MB的数据耗时250000纳秒,从磁盘中顺序读取1MB的数据耗时20000000纳秒,内存的读取速度是硬盘的读取速度的80倍。因此可以通过把内存数据存储在内存来提升系统的性能。
Redis就是一个满足上面需求的开源Kev-Value内存存储系统。Kev-Value存储系统在写入的时候,通过指定Kev及其对应的Value;读取的时候,通过指定Kev就能读取Value的值。Redis有以下的特点。
·全部的数据操作在内存,保证了高速的读写速度。
·提供丰富多样的数据类型:string、hash、list. set. sorted set、bitmap和hyperloglog。
·提供了AOF和RDB两种数据的持久化方式,保证了Redis重启后数据不丢失。
·Redis的所有操作都是原子性,同时Redis还支持对几个操作合并后的原子性操作,也即支持事务。
Redis丰富多样的数据类型给数据存储提供了种新的思路,其让广大的开发者存储数据的时候,不用再面对功能单的数据库,APP开发者能利用Redis提供的灵活多变的数据结构和数据操作更巧妙地存储数据。
制作APP关于Redis的常用数据绪构及应用场景
深圳APP开发公司下面介绍Redis 5种常用的数据结构(striug、hash、list. set. sorted s et),以及这些数据结构所适用的业务场景。
本文今天介绍第一种:string--存储简单的数据
1.简介
string类型是Redis中最基本的数据类型,其在Redis中是二进制安全,意味着这种数据类型可以接受任何格式的二进制数据,例如一张JPEG格式的图片或者JSON格式的字符串。在Redis中字符串类型最多可以容纳的数据长度是512MB。
2.数据模型
string类型是基本的Kev-Value结构,Key可以看作某个数据在Redis中的唯标识,Value是具体的数据。表7-2展示了基本Key-Value数据模型:
APP制作示意表7-2基本Key-Value数据模型
在表7-2中.Kev为“name”,对应Value为“jeff”;Kev为“citv”,对应Value为“Guaguzhou”。
3.应用场景
由于string类型灵活,可以存储大量的数据,所以在App后台中,string类型经常会用来缓存数据。例如App中常见的商品分类栏,这类界面的特点是:访问频率而,数据不经常变动(可能几天)。所以为了提而这个界面的访问速度,把这个界面的数据放在Redis的个Kev-Value结构中,一般情况下App后台就从这个Kev读取数据;当这个界面的数据发生变化时,用新的数据覆盖这个Kev的数据。假没这个界面的数据对应的Kev是“category”Value/J这个界面的JSON数据,则Redis中对应的模型如表7-3所示
制作APP操作示意图表7-3分类界而对应的Key-Value
当App端需要通过API获取这个界面的JSON数据时,API请求到达App后台通过Redis获取Key“category”对应的值,命令如下。
get category
一般来说,App端为了在网络不可用的时候也有良好的用户体验,会在App本地也缓存份数据,整个流程如图7-4所示。
制作APP示意图7-4APP显示分类栏目流程图
好了,APP开发公司关于制作APP时对于Redis功能介绍以及它的常用五种数据结构中的第一种,本文就天就介绍到这里。博纳网络会在下期里面继续介绍第二种,喜欢本站敬请持续关注。谢谢