麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 數據庫 > Redis > 正文

巨大Redis分割的具體操作思路

2020-02-17 14:56:01
字體:
來源:轉載
供稿:網友

薄荷 App 上的伙伴功能大量使用了內存數據庫 Redis,隨著數據量的快速增長,Redis 膨脹得很快,已經接近 12 GB規模,這些數據全部放在單個 Redis 實例中。單個巨大 Redis 實例有如下幾個壞處:

1.首先,需要一臺內存很大的機器。Redis 是內存數據庫,它需要把所有需求全部放在內存中,需要為之裝下 12 GB的 Redis 實例,至少需要 12 GB 內存大小的機器,考慮的預留增長空間,一般需要 12 * 1.5 約 18 GB 內存。 另外還有一個考慮的因素是,Redis 進行硬盤數據存儲時,fork 進程需要消耗同樣大小的內存,因此一個 12GB 的 redis 實例需要 32 GB左右的內存比較合適,這對機器提出了很高的要求,常常難以滿足。

2.然后,Redis 容易成為性能瓶頸。Redis 的并發模型是單進程單線程,它不能充分利用多核 CPU,在請求數很高,或者某一些請求處理比較慢時(比如一些大的數據排序),可能會成為系統的性能瓶頸。有方法可以緩解甚至這個問題,就是建立多個 Redis 實例,通過多個 Redis 連接來實現。

3.另外,單個巨大的 Redis 實例也會增加數據管理難度,因為這么大的數據量,無論是復制,備份操作都比較慢,容易對線上系統造成沖擊。

因此,十分有必要把單個巨大的 Redis 實例分割成多個小的 Redis 實例。

使用 Redis 的復制機制,可以在線平滑處理 Redis 實例分割,幾乎不會對系統有很大的影響。

分割的具體操作思路如下:

1.首先,規劃 Redis 分割策略,通常是基于業務劃分,比如薄荷伙伴是基于業務分成 timeline, user_relationship, other 3個 Redis 實例。規劃好之后,需要根據規劃結果對應用程序中 Redis 程序代碼做修改,通常是有一個統一的 Redis 鏈接修改為多個 Redis 連接,不同業務使用不同的連接。

2.然后,通過 Redis 復制功能建立多個 Redis 副本,讓不同 Redis 連接使用不同的 Redis 副本,在 Redis 副本中刪除多余的數據。批量刪除某個模式的 keys,可以使用下面的 shell 命令:


redis-cli KEYS "" | xargs redis-cli DEL

?

改成實際的模式,如


redis-cli KEYS "user:*:followers" | xargs redis-cli DEL

?

表示刪除 user followers 數據。

最后通過來回切換并重啟 Redis 實例達到完全分割 Redis 實例。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表

圖片精選

主站蜘蛛池模板: 亚洲午夜在线视频 | 国产精品久久久久久久久久久久久久久久 | 午夜视频在线看 | 久久第四色 | 日本黄色一级视频 | 国产精品视频免费网站 | 久久久久亚洲a | 日日噜噜噜夜夜狠狠久久蜜桃 | 国产资源在线免费观看 | 91av99| 久久久久久精 | 看国产毛片 | 国产一区二区三区在线免费观看 | 国产成年人视频网站 | 欧美一级特级 | 97久久日一线二线三线 | 在线免费小视频 | 亚洲电影在线观看高清免费 | 少妇一级淫片免费放播放 | 久久久久国产成人免费精品免费 | 羞羞羞网站 | 狠狠干五月天 | 亚洲黑人在线观看 | 国产一区二区在线免费观看 | 国产一级性生活视频 | 国产精品av久久久久久网址 | 中文字幕在线视频日本 | 亚洲一区在线免费视频 | 久久影院一区二区三区 | 欧美日日操 | 黄色片视频在线观看 | 亚欧美一区二区 | 7777网站| 日产精品一区二区三区在线观看 | 久草成人在线 | 久久91精品 | 欧美成人精品欧美一级乱黄 | 久久精品视频亚洲 | 免费放黄网站在线播放 | 国产精品wwww| 国产91免费看 |