##### 概念:
在默認情況下,用戶請求數據時,會先在緩存(Redis)中查找,若沒找到即緩存未命中,再在數據庫中進行查找,數量少可能問題不大,可是一旦大量的請求數據(例如秒殺場景)緩存都沒有命中的話,就會全部轉移到數據庫上,造成數據庫極大的壓力,就有可能導致數據庫崩潰。網絡安全中也有人惡意使用這種手段進行攻擊被稱為洪水攻擊。
##### **解決方案:**
* 布隆過濾器
對所有可能查詢的參數以Hash的形式存儲,以便快速確定是否存在這個值,在控制層先進行攔截校驗,校驗不通過直接打回,減輕了存儲系統的壓力。
* 緩存空對象
一次請求若在緩存和數據庫中都沒找到,就在緩存中方一個空對象用于處理后續這個請求。
存在的問題 : 1、如果空值能夠被緩存起來,這就意味著緩存需要更多的空間存儲更多的鍵,因為這當中可能會有很多的空值的鍵。 2、即使對空值設置了過期時間,還是會存在 緩存層和存儲層 的數據會有一段時間窗口的不一致的問題,對于需要保持一致性的業務會有影響。
- Redis 介紹
- 為什么要用Nosql
- Memcached(緩存)+Mysql+ 垂直拆分
- 分庫分表+水平拆分+Mysql集群
- 什么是Nosql
- Nosql的特點
- 了解 3V+ 3高
- Redis 入門
- 概述
- Redis 能干啥
- 特性
- 常用網站
- 端口
- 查看redis是否啟動
- Redis 基本操作
- Redis切換數據庫
- 查看所有的key
- 清空當前數據庫跟清除所有數據庫
- 五大數據類型
- Redis Key
- 檢測key值是否存在
- 移除key值
- 設置keyzhi10秒鐘后消失
- 查看當前key的類型
- String(類型)
- 設置字符串
- 獲取字符串
- 追加一個值到字符串
- 獲取字符串長度
- 自增跟自減
- 字符串范圍 range
- 替換指定開始的字符串
- 設置過期時間
- 設置多個字符串/獲取多個字符串
- 檢測值不存在在創建
- List(列表類型)
- 介紹
- 左邊塞入一個值
- 獲取值
- 左邊塞入多個值
- 右邊塞入一個值
- 移除左邊或右邊第一個值
- 通過下標獲取值
- 獲取長度
- 移除指定的值
- 截取固定的值
- 移除列表最后一個元素,將他移動新的列表中
- 檢測列表是否存在
- 將列表中指定下標的值替換為另外一個值
- 往指定列表值前后插入數據
- 消息隊列 跟棧
- SET(集合)操作
- 注意
- 添加一個或多個值
- 集合獲取值
- 判斷某一個值是否在集合中
- 獲取集合中的個數
- 移除某一個元素
- 隨機一個元素
- 隨機刪除一個元素
- 移動指定的值到另一個集合中
- 交集 并集 差集
- HASH(哈希)
- Hash介紹
- 設置一個或多個值
- 獲取一個或多個值
- 獲取所有的值
- 刪除一個值
- hash獲取長度
- 判斷某個值是否存在
- 獲取所有key 跟所有value
- 自增
- 如果不存在可以設置值 /如果存在不可以設置
- 總結
- ZSEt(有序集合)
- zset添加一個或多個值
- 查看值
- 顯示全部的用戶 從小到大
- 從大到下排列
- 顯示全部的用戶,并且攜帶成績
- 顯示工資小于2900員工升序排列
- 移除元素
- 獲取個數
- 獲取指定區間的成員數
- 五大類型介紹
- 三種特殊數據類型
- geospatial(地理位置)
- HyperLoglog
- Bitmaps
- 哨兵模式的全部配置
- 事務
- Redis事務本質
- Redis 的事務流程
- 放棄事務
- 錯誤
- 悲觀鎖 與樂觀鎖
- 解鎖
- Redis配置文件詳解
- Redis 持久化
- RDB
- AOF(Append Only File)
- 發布訂閱
- Redis 主從復制
- 哨兵模式
- Redis緩存穿透(查不到
- Redis緩存擊穿(查太多了)
- Redis緩存雪崩
- laravel 操作Redis
- 配置redis
- laravel 操作 String 類型
- laravel 操作 List (隊列集合)
- laravel 操作 SET(集合)操作
- laravel 操作 ZSET(有序集合)
- laravel 操作 Hash(哈希)
- laravel 個人案例/其他業余配置