Redis篇-第1章 Redis入门概述

第一节 Redis 概述

1、是什么

        Redis(Remote Dictionary Server)远程字典服务器,完全开源,使用 ANSIC 语言编写遵守 BSD 协议,是一个高性能的 Key-Value 数据库。提供了丰富的数据结构,例如String、Hash、List、Set、SortedSet 等等。

2、特点

        Redis 是一种键值型的 NoSql 数据库,NoSql:数据非结构化、数据之间无关联、查询方式为非 SQL        

        数据是存在内存中的,同时Redis支持事务、持久化、LUA脚本、发布/订阅、缓存淘汰、流技术等多种功能特性,提供了主从模式、Redis Sentinel 和 Redis Cluster 集群架构方案。

  • 键值(key-value)型,value 支持多种不同数据结构,可以是字符串、数值、json
  • 单线程,每个命令具备原子性
  • 低延迟,速度快(基于内存、IO多路复用、良好的编码)
  • 支持数据持久化
  • 支持主从集群、分片集群
  • 支持多语言客户端

3、相关地址

        英文官网地址:Redis - The Real-time Data Platform

        中文官网地址:Redis中文网

        下载地址:Downloads - Redis

        Redis源码地址:GitHub - redis/redis: Redis is an in-memory database that persists on disk. The data model is key-value, but many different kind of values are supported: Strings, Lists, Sets, Sorted Sets, Hashes, Streams, HyperLogLogs, Bitmaps.

        Redis在线测试:try.redis.io

        Redis命令参考:Redis 命令参考 — Redis 命令参考 (redisfans.com)

第二节 Redis 功能与作用

  • 分布式缓存,挡在 Mysql 数据库之前的带刀侍卫
  • 分布式锁
  • 消息队列
  • 高可用架构搭配:主从、哨兵、集群
  • 内存存储 + 持久化(RDB+AOF):Redis 支持异步将内存中的数据写到硬盘上,同时不影响继续服务
  • 排行榜 + 点赞:zset

第三节 认识 NoSql

        NoSql 可以翻译做Not Only Sql(不仅仅是SQL),或者是No Sql(非Sql的)数据库。是相对于传统关系型数据库而言,有很大差异的一种特殊的数据库,因此也称之为非关系型数据库

1、结构化与非结构化

        传统关系型数据库是结构化数据,每一张表都有严格的约束信息:字段名、字段数据类型、字段约束等等信息,插入的数据必须遵守这些约束:

而NoSql则对数据库格式没有严格约束,往往形式松散,自由。

可以是键值型:

也可以是文档型:

甚至可以是图格式:

2、关联和非关联

        传统数据库的表与表之间往往存在关联,例如外键:

        而非关系型数据库不存在关联关系,要维护关系要么靠代码中的业务逻辑,要么靠数据之间的耦合:  

{
  id: 1,
  name: "张三",
  orders: [
    {
       id: 1,
       item: {
	 id: 10, title: "荣耀6", price: 4999
       }
    },
    {
       id: 2,
       item: {
	 id: 20, title: "小米11", price: 3999
       }
    }
  ]
}

        此处要维护“张三”的订单与商品“荣耀”和“小米11”的关系,不得不冗余的将这两个商品保存在张三的订单文档中,不够优雅。还是建议用业务来维护关联关系。  

3、查询方式

        传统关系型数据库会基于Sql语句做查询,语法有统一标准;而不同的非关系数据库查询语法差异极大,五花八门各种各样。

4、事务

        传统关系型数据库能满足事务ACID的原则。而非关系型数据库往往不支持事务,或者不能严格保证ACID的特性,只能实现基本的一致性。

5、总结

        除了上述四点以外,在存储方式、扩展性、查询性能上关系型与非关系型也都有着显著差异,总结如下:

  • 存储方式

    • 关系型数据库基于磁盘进行存储,会有大量的磁盘IO,对性能有一定影响

    • 非关系型数据库,他们的操作更多的是依赖于内存来操作,内存的读写速度会非常快,性能自然会好一些

  • 扩展性

    • 关系型数据库集群模式一般是主从,主从数据一致,起到数据备份的作用,称为垂直扩展。

    • 非关系型数据库可以将数据拆分,存储在不同机器上,可以保存海量数据,解决内存大小有限的问题。称为水平扩展。

    • 关系型数据库因为表之间存在关联关系,如果做水平扩展会给数据查询带来很多麻烦

        

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值