本章博客讲解关系型数据库和非关系数据库简单介绍+Redis的相关理论概念和安装。

关系型数据库:

SqlServer,MySql,Oracle,SQLite,MariaDB,PostgreSQL....
关系型数据库最典型的数据结构是表,由二维表及其之间的联系所组成的一个数据组织
优点:
1、易于维护:都是使用表结构,格式一致;
2、使用方便:SQL语言通用,可用于复杂查询;
3、复杂操作:支持SQL,可用于一个表以及多个表之间非常复杂的查询。
缺点:
1、读写性能比较差,尤其是海量数据的高效率读写;
2、固定的表结构,灵活度稍欠;
3、高并发读写需求,传统关系型数据库来说,硬盘I/O是一个很大的瓶颈。

非关系型数据库:

mongoDB,redis,CouchDB,HBASE......
非关系型数据库严格上不是一种数据库,应该是一种数据结构化存储方法的集合,可以是文档或者键值对等。
优点:
1、格式灵活:存储数据的格式可以是key,value形式、文档形式、图片形式等等,文档形式、图片形式等等,使用灵活,应用场景广泛,而关系型数据库则只支持基础类型。
2、速度快:nosql可以使用硬盘或者随机存储器作为载体,而关系型数据库只能使用硬盘;
3、高扩展性;
4、成本低:nosql数据库部署简单,基本都是开源软件。
缺点:
1、不提供sql支持,学习和使用成本较高;
2、无事务处理;
3、数据结构相对复杂,复杂查询方面稍欠。

非关系型数据库的分类和比较:

1、文档型
2、key-value型
3、列式数据库
4、图形数据库

关系型数据库如何存储图结构 关系数据库的存储结构_关系型数据库


关系型数据库如何存储图结构 关系数据库的存储结构_redis_02


关系型数据库如何存储图结构 关系数据库的存储结构_redis_03


关系型数据库如何存储图结构 关系数据库的存储结构_关系型数据库如何存储图结构_04

redis理论概念:

Redis 本质是一个基于内存的高性能key-value非关系型数据库。

特点:

Redis本质上是一个Key-Value类型的内存数据库,很像memcached,整个数据库统统加载在内存当中进行操作,定期通过异步操作把数据库数据flush到硬盘上进行保存。因为是纯内存操作,Redis的性能非常出色,每秒可以处理超过 10万次读写操作,是已知性能最快的Key-Value DB。

Redis的出色之处不仅仅是性能,Redis最大的魅力是支持保存多种数据结构,此外单个value的最大限制是1GB,不像 memcached只能保存1MB的数据,因此Redis可以用来实现很多有用的功能,比方说用他的List来做FIFO双向链表,实现一个轻量级的高性能消息队列服务,用他的Set可以做高性能的tag系统等等。另外Redis也可以对存入的Key-Value设置expire时间,因此也可以被当作一 个功能加强版的memcached来用。

优点(好处)

(1) 速度快,因为数据存在内存中,类似于HashMap,HashMap的优势就是查找和操作的时间复杂度都是O(1)
  (2) 支持丰富数据类型,支持string,list,set,sorted set,hash 
  (3) 支持事务,操作都是原子性,所谓的原子性就是对数据的更改要么全部执行,要么全部不执行
  (4) 丰富的特性:可用于缓存,消息,按key设置过期时间,过期后将会自动删除

缺点

Redis的主要缺点是数据库容量受到物理内存的限制,不能用作海量数据的高性能读写,因此Redis适合的场景主要局限在较小数据量的高性能操作和运算上。

海量数据的高性能读写:可以使用Hbase(大数据)

redis中常用的数据类型:

String,Hash,List,Set,Sorted set,pub/sub,Transactions。

redis常见性能问题和解决方案:

1).Master写内存快照,save命令调度rdbSave函数,会阻塞主线程的工作,当快照比较大时对性能影响是非常大的,会间断性暂停服务,所以Master最好不要写内存快照。

2).Master AOF持久化,如果不重写AOF文件,这个持久化方式对性能的影响是最小的,但是AOF文件会不断增大,AOF文件过大会影响Master重启的恢复速度。Master最好不要做任何持久化工作,包括内存快照和AOF日志文件,特别是不要启用内存快照做持久化,如果数据比较关键,某个Slave开启AOF备份数据,策略为每秒同步一次。

3).Master调用BGREWRITEAOF重写AOF文件,AOF在重写的时候会占大量的CPU和内存资源,导致服务load过高,出现短暂服务暂停现象。

4).Redis主从复制的性能问题,为了主从复制的速度和连接的稳定性,Slave和Master最好在同一个局域网内

Reids安装

Window 安装

下载地址:https://github.com/MSOpenTech/redis/releases。

Redis 可支持 32 位和 64 位。这个根据你系统平台的实际情况选择,
现在下载 Redis-x64-xxx.zip压缩包到 D 盘,解压后,将文件夹重新命名为 redis。

打开文件夹

关系型数据库如何存储图结构 关系数据库的存储结构_Redis_05

打开一个 cmd 窗口 使用 cd 命令切换目录到 D:\Program Files\redis 运行:

输入 redis-server.exe redis.windows.conf 命令

关系型数据库如何存储图结构 关系数据库的存储结构_Redis_06

这个时候再开启一个 cmd 窗口,原来的不要关闭,不然就无法访问服务端了。

切换到 redis 目录下运行:
redis-cli.exe -h 127.0.0.1 -p 6379

设置键值对:
set myKey szh

取出键值对:
get myKey

关系型数据库如何存储图结构 关系数据库的存储结构_关系型数据库_07


Linux 安装

官方下载地址:https://redis.io/download

页面有三种版本,Unstable, Stable, 以及Docker . 我们选择Statbele下载即可。

打开虚拟机输入以下命令:
$ wget http://download.redis.io/releases/redis-2.8.17.tar.gz

记得安装wget命令
yum -y install wget

$ tar xzf redis-2.8.17.tar.gz
$ cd redis-2.8.17
$ make

make完后 redis-2.8.17目录下会出现编译后的redis服务程序redis-server,还有用于测试的客户端程序redis-cli,两个程序位于安装目录 src 目录下:
下面启动redis服务
$ cd src
$ ./redis-server

注意这种方式启动redis 使用的是默认配置。也可以通过启动参数告诉redis使用指定配置文件使用下面命令启动。
$ cd src
$ ./redis-server ../redis.conf

redis.conf 是一个默认的配置文件。我们可以根据需要使用自己的配置文件。
启动redis服务进程后,就可以使用测试客户端程序redis-cli和redis服务交互了。 比如:
$ cd src
$ ./redis-cli
redis> set foo bar
OK
redis> get foo
"bar"