0 使用理由

0.1 高性能

  • 纯内存操作,比在硬盘操作数据的速度有极大提升

0.2 高并发

  • 承受请求比直接操作数据库大得多

0.3 单线程

  • 至于redis单线程的原因。有点意思。CPU不是Redis的主要瓶颈,因为Redis通常是内存或网络绑定。例如,一般Linux系统上运行的Redis每秒甚至可以提供100万个请求,因此不会使用太多的CPU。言下之意,就是说redis根本不需要多线程,况且多线程会有上下文切换消耗。当然可以通过启动多个redis实例,达到利用cpu的目的。

1 缓存使用

1.1 使用场景

  • 读对于写,为了减少数据库访问的id操作,可以将数据缓存,提高系统性能

1.2 使用方法

  • 查询

    1. 查出数据后,利用json将数据转成String类型,存进reids
  • 更新
    1. 先把数据更新到数据库
    2. 删除reids的key

2 缓存雪崩

2.1 what

  • 由于缓存时间相近或者redis宕机导致缓存数据同一时间大面积失效,使得数据库短时间请求增多,增加数据库压力,减低数据库访问性能

2.2 how(解决):

  • 事前:

    1. 宕机导致:的保证redis高可用,发现机器宕机,及时补上。选择合适的内存淘汰策略
    2. 缓存失效时间相同导致的:在设计时间的时候随机加减几分钟
  • 事后:
    1. 宕机导致的: 利用redis持久化机制保存的数据及时恢复缓存

3 缓存穿透

3.1 what(是什么)

  • 请求缓存中不存在的数据,使得数据库压力增大,从而崩掉

3.2 how:(解决)

  • 布隆过滤器
  • 直接缓存他(空的),设计一个较短时间,使其失效

4 Redis数据类型

  • String 字符串
  • Hash哈希 :用户ID
  • List列表 :粉丝列表
  • Set集合 :共同好友
  • Sorted Set有序集合:排行榜

5 主从复制

5.1 定义/解释

建立一个与主数据库一样的数据库环境,称为从数据库,主复制库一般是准实时的业务数据库。

5.2 作用

  • 作为备用数据库,主数据库发生故障后,切换到从数据库
  • 架构扩展,业务量增大,io访问频繁,做多库的存储,提高io性能
  • 实现读写分离。

5.3 原理

  • 将主数据库中的bin-log文件的sql语句复制到从数据库中的relay-log文件,再次执行。

5.4 Redis哨兵

  • 用途:

    1. 监视主从数据库运行情况
    2. 主数据库发生故障后,自动切换到从数据库

6 卡顿现象

6.1 解决方法:

  • 使用show global status
  • 使用show processlist
  • 使用查询日志

7 大数据查询优化

  • 优化sql语句 索引
  • 使用主从复制,实现读写分离
  • 加入缓存 如redis

redis数据库学习的更多相关文章

  1. 【redis数据库学习】用JAVA连接redis数据库各种报错

    最近项目中,需要用到redis数据库,然后使用Jedis让JAVA连接redis. 首先,安装redis数据库,参考的是:http://www.runoob.com/redis/redis-insta ...

  2. redis数据库学习笔记

    redis数据库 工作需要,简单了解一下redis数据库,供后续参考和复习使用. 一.简介 Redis是一个开源(BSD许可),内存存储的数据结构服务器,可用作数据库,高速缓存和消息队列代理.它支持字 ...

  3. Redis 数据库学习

    安装(mac) 使用homebrew安装,命令是:brew install redis. 安装完成后启动命令:brew services start redis. 使用命令redis-cli进入red ...

  4. 项目开发git-短信验证-redis数据库

    项目开发git操作 基本流程 """ 1.开发前,拉一次远程仓库 2.工作区进行开发 3.将开发结果提交到本地版本库 - git status查看时没有待处理的事件 4. ...

  5. 数据库学习番外篇 神奇的Redis

    数据库学习番外篇 神奇的Redis 由于最近呢小猿我找到了自己的女神,所以整个学习计划都被打乱了,本来想着一天看一张<SQLServer宝典>的.没成想,我竟然脱离了单身狗的队伍. 最近准 ...

  6. 【Redis数据库】命令学习笔记——发布订阅、事务、脚本、连接等命令汇总

    本篇基于redis 4.0.11版本,学习发布订阅.事务.脚本.连接的相关命令. Redis 发布订阅(pub/sub)是一种消息通信模式:发送者(pub)发送消息,订阅者(sub)接收消息. 序号 ...

  7. 小白学习 Redis 数据库日记(2017-06-13)

    redis 127.0.0.1:6379> LPUSH runoobkey redis(integer) 1redis 127.0.0.1:6379> LPUSH runoobkey mo ...

  8. Redis学习(5)-Jedis(Java操作redis数据库技术)

    Java连接redis 一,导入jar包 Redis有什么命令,Jedis就有什么方法 设置防火墙 在Linux上面运行如下代码: 单实例:Jedis实例: package com.jedis.dem ...

  9. python学习笔记(十六)python操作redis数据库

    Redis是一个key-value存储系统,它支持丰富的数据类型,如:string.list.set.zset(sorted set).hash. Redis特点 Redis以内存作为数据存储介质,所 ...

随机推荐

  1. Wpf窗口设置屏幕居中最前显示

    public Window()         {             InitializeComponent();             WindowStartupLocation = Win ...

  2. Activity 使用详解

    极力推荐文章:欢迎收藏 Android 干货分享 阅读五分钟,每日十点,和您一起终身学习,这里是程序员Android 本篇文章主要介绍 Android 开发中的部分知识点,通过阅读本篇文章,您将收获以 ...

  3. win系统上Anaconda国内镜像配置

    清华镜像2019.6.15已恢复 中科大镜像2019.7.1停机维护后恢复 1.打开anaconda prompt 2.添加清华镜像1:https://mirrors.tuna.tsinghua.ed ...

  4. PHP 的一些开发规范

    均需要遵守 PSR规范 变量命名 不用拼音 驼峰或下划线风格要一致 单词要有意义 不用关键字 常量全大写用下划线连接 代码注释 尽量让代码可读性提高,减少代码上的注释 函数头部可以描述参数和返回值及功 ...

  5. Vue系列:Vue Router 路由梳理

    Vue Router 是 Vue.js 官方的路由管理器.它和 Vue.js 的核心深度集成,让构建单页面应用变得易如反掌.包含的功能有: 嵌套的路由/视图表 模块化的.基于组件的路由配置 路由参数. ...

  6. CSS3: @font-face 介绍与使用

    @font-face 是CSS3中的一个模块,他主要是把自己定义的Web字体嵌入到你的网页中,随着@font-face模块的出现,我们在Web的开发中使用字体不怕只能使用Web安全字体,你们当中或许有 ...

  7. Unix-IO-同步,异步,阻塞,非阻塞-笔记篇

    概念更正 https://www.zhihu.com/question/19732473 错误的四个象限分类 https://www.ibm.com/developerworks/cn/linux/l ...

  8. 洛谷 P3648 [APIO2014]序列分割

    题意简述 有一个长度为n的序列,分成k + 1非空的块, 选择两个相邻元素把这个块从中间分开,得到两个非空的块. 每次操作后你将获得那两个新产生的块的元素和的乘积的分数.求总得分最大值. 题解思路 f ...

  9. nginx 使用HTTPS协议-SSL证书模块报错解决-附nginx安装 : [emerg] the "ssl" parameter requires ngx_http_ssl_module in nginx.c

    Linux系统下ngnix使用HTTPS协议启动报错: nginx: [emerg] the "ssl" parameter requires ngx_http_ssl_modul ...

  10. Java并发之内存模型(JMM)浅析

    背景 学习Java并发编程,JMM是绕不过的槛.在Java规范里面指出了JMM是一个比较开拓性的尝试,是一种试图定义一个一致的.跨平台的内存模型.JMM的最初目的,就是为了能够支多线程程序设计的,每个 ...