Tair分散式緩存

来源:https://www.cnblogs.com/xiexj/archive/2019/10/11/11652107.html
-Advertisement-
Play Games

Tair是為瞭解決什麼問題而生? Redis很好用,相比memcached多了很多數據結構,支持持久化。但是在很長一段時間里,原生是不支持分散式的。後來就出現了很多redis集群類產品,Tair是其中勝出的優秀作品之一。 所以Tair的特性都是一些集群的特性,比如:容錯、解決單點故障、跨機房管理、多 ...


Tair是為瞭解決什麼問題而生?

    Redis很好用,相比memcached多了很多數據結構,支持持久化。但是在很長一段時間里,原生是不支持分散式的。後來就出現了很多redis集群類產品,Tair是其中勝出的優秀作品之一。

    所以Tair的特性都是一些集群的特性,比如:容錯、解決單點故障、跨機房管理、多集群管理、支持副本等。總而言之,是redis的高可用版本。

 

Tair的架構

    Tair的整體風格是簡約實用,包括三個必選模塊:client、configserver和dataserver。一個可選模塊:invalidserver。還有一個必要軟設施:一致性哈希演算法提供分散式的負載均衡計算。

 

 

client的作用

    1. 在應用端提供訪問Tair集群的介面

    2.更新並緩存數據分佈表和invalidserver 地址等
    3. 本地緩存,避免過熱數據訪問影響Tair集群服務

    4. 流控

configserver的作用

    1. 通過維護和dataserver心跳來獲取集群存活節點的信息

    2.通過存活節點的信息來構建數據在集群中的分佈表

    3. 提供數據分佈表的查詢服務

    4. 調度dataserver之間的數據遷移、複製

dataserver的作用

     1. 提供存儲引擎

     2. 接受client和put、get、remove等操作

     3. 執行數據遷移、複製等

     4. 插件:在接受請求的時候處理一些自定義功能

     5. 訪問統計

 invallidserver的作用

     1. 接收來自client和invalid、hide等請求後,對屬於同一組的集群(雙機房獨立集群部署方法)做delete、hide操作,保證同一組集群的一致

     2.集群斷網之後的臟數據清理

     3. 訪問統計

一致性哈希的作用

    1. 增加和減少dataserver的時候,進行rehash重哈希。併在遷移過程中保持原數據對外提供服務

    2. 負載均衡,並行多個key進行計算合併結果(mget)

 

Tair的使用場景

  1. 緩存

  2. 分散式鎖

  3. 作為nosql資料庫,提供簡單類型存儲(K/V存儲,無複雜查詢)

 

Tair使用QA

1.

Q:tair可以支持支持什麼類型?

A:內部是序列化成二進位的,就是說理論上支持任何類型。

2.

Q:tair有mget的功能可以一次性返回多個結果,這個個數有上限嗎?

A:理論上沒有。實際使用中建議1次在100個以下。因為多個請求要等所有的結果回來再進行聚合。聚合等待太多,錯誤就會發生。好比一個機器故障率是萬分之一。那麼10000條記錄一起請求結果,那麼故障率就非常高了,可能多數情況下都是失敗的。

3.

Q:tair的分散式鎖使用有什麼最佳實踐?

A:分散式鎖使用建議使用帶有過期時間的分散式鎖,過期時間可傳一個絕對的時間戳。解鎖時可傳入一個非常大的整數,以解掉所有的鎖。


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 常見的有 、`強制瀏覽器全屏 IOS的Web APP模式 可點擊元素出現陰影` 本文主要講一些其他的或者實用的優化手段。 1. 彈出數字鍵盤 跟`IOS pattern input`的類型了。 2. 調用系統的某些功能 3. 打開原生應用 這種方式叫做 ,是一種協議,一般用來訪問 或者 中的某個功能 ...
  • 開發前準備 vue.js2.0中文,項目所使用的js框架 vue-router,vue.js配套路由 vuex,狀態管理 Element,UI框架 1,根據官方指引,構建項目框架 2,使用webpack+ sass 來寫css less是一門css預處理語言,它是拓展了css,增加了變數,Mixin ...
  • 解決Idea、WebStorm下使用Vue cli腳手架項目無法使用Webpack別名的問題 ...
  • 為什麼要用css動畫替換js動畫 導致JavaScript效率低的兩大原因:操作DOM和使用頁面動畫。 用CSS3動畫替代JS模擬動畫的好處: 不占用JS主線程; 可以利用硬體加速; 瀏覽器可對動畫做優化(元素不可見時不動畫減少對FPS影響) CSS3動畫提供了2D和3D以及常規動畫屬性介面,它可以 ...
  • 1、安裝、構建 2、項目目錄 3、antd 修改 src/App.css,在文件頂部引入 antd/dist/antd.css。 antd 目前的預設文案是英文,如果需要使用其他語言,可以參考下麵的方案。 antd 提供了一個 React 組件 ConfigProvider 用於全局配置國際化文案。 ...
  • 之前講解了什麼是微服務:微服務的核心在於服務治理,微服務架構是將複雜臃腫的單體應用進行細粒度的服務化拆分,每個拆分出來的服務各自獨立打包部署,並交由小團隊進行開發和運維,從而極大地提高了應用交付的效率。 什麼時候進行服務化拆分?拆分單體應用有哪些標準呢? 什麼時候進行服務化拆分? 比如做社交 App ...
  • 1 面向對象簡述 將 {1,3,45,56,78,90}轉化為[1,3,45,56,78,90] 1 2 方法1:面向過程 public class Student { int age = 13; String name = "wangsiyu"; public void study(){ Syst ...
  • 一、Django的內置分頁器(paginator) view index.html: 擴展 show.html model.py文件內容: 二、自定義分頁 當資料庫中數據有很多,我們通常會在前端頁面做分頁展示。 分頁的數據可以在前端頁面實現,也可以在後端實現分頁。 後端實現分頁的原理就是每次只請求一 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...