redis 一二事 - 搭建集群緩存伺服器

来源:http://www.cnblogs.com/leechenxiang/archive/2016/04/28/5441126.html
-Advertisement-
Play Games

在如今併發的環境下,對大數據量的查詢採用緩存是最好不過的了,本文使用redis搭建集群 (個人喜歡redis,對memcache不感冒) redis是3.0後增加的集群功能,非常強大 集群中應該至少有三個節點,每個節點有一備份節點。這樣算下來至少需要6台伺服器 考慮到有些朋友的電腦配置不是很高,跑多 ...


在如今併發的環境下,對大數據量的查詢採用緩存是最好不過的了,本文使用redis搭建集群

(個人喜歡redis,對memcache不感冒)

redis是3.0後增加的集群功能,非常強大

集群中應該至少有三個節點,每個節點有一備份節點。這樣算下來至少需要6台伺服器

考慮到有些朋友的電腦配置不是很高,跑多個虛擬機就會卡,這邊放出偽分散式和分散式

(2年前的配置)

前提先裝好一個單例情況下的redis(這裡就不多說了)

需要6redis實例

 

搭建集群的步驟:

 

在/usr/local下 創建文件夾   這個我是把原來的單例redis改了個名字做的     進入redis01/bin 刪除dump文件   修改埠   打開註釋   複製多份 (真實環境下只需要一個就行,然後其餘5台機子重覆以上操作) 指定埠從70017006   這是真實環境下的 占用率     redis源碼文件夾下的src目錄下。redis-trib.rb,這個ruby腳本     第四步:把redis-trib.rb文件複製到到redis-cluster目錄下。 (真實環境下,只需要放在你某個節點機子上就行,他會自動遍歷到其他的節點上的,我做的時候放在了01上)   執行ruby腳本之前,需要安裝ruby環境,不然裝不了 yum install ruby     yum install rubygems       安裝redis-trib.rb運行依賴的ruby的包 這個gem可以網上下載,很多     (真實環境下只需要在其中一臺機子上運行就行了)     進入各自的redis文件夾,分別啟動所有的redis實例   啟動成功   使用redis-trib.rb創建集群 不管是不是偽分散式,這隻需要啟動一次   成功~!   鏈接第一個節點     下麵演示使用jedis來讀寫緩存 當然加入spring中一定要使用單例
 1 @Test
 2     public void testCluster() throws Exception {
 3         Set<HostAndPort> nodes = new HashSet<>();
 4         nodes.add(new HostAndPort("192.168.1.193", 7001));
 5         nodes.add(new HostAndPort("192.168.1.194", 7002));
 6         nodes.add(new HostAndPort("192.168.1.195", 7003));
 7         nodes.add(new HostAndPort("192.168.1.196", 7004));
 8         nodes.add(new HostAndPort("192.168.1.197", 7005));
 9         nodes.add(new HostAndPort("192.168.1.198", 7006));
10         JedisCluster jedisCluster = new JedisCluster(nodes);
11         jedisCluster.set("name", "lee");
12         jedisCluster.set("age", "18");
13         String name = jedisCluster.get("name");
14         String value = jedisCluster.get("age");
15         System.out.println(name);
16         System.out.println(value);
17         jedisCluster.close();
18     }

運行結果:

可以看到redis客戶端上取數據的時候IP是不一樣的

                 

 


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

-Advertisement-
Play Games
更多相關文章
  • 今天學習,如標題。創建一個類,欄位屬性構造函數:Source code: using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.Threading.Task ...
  • abstract 用關鍵字abstract修飾的類叫做抽象類,且只能作為基類,也不能實例化。 用abstract定義的抽象類中不一定只包含抽象方法 ,可以包含非抽象方法。 abstract定義的方法一定用放在抽象類中。 派生類中一定要實現抽象類中的所有的抽象方法,否則派生類也要聲明為抽象類。 抽象方 ...
  • 0x00 前言 寫網站的時候,或多或少會遇到,登錄,註冊等操作,有時候,為了防止別人批量進行操作,不得不做出一些限制IP的操作(當前也可以用於限制某個賬號的密碼校驗等)。 這樣的簡單限制,我們又不想對數據進行存庫(顯得過於浪費資源了)。所以就誕生了0x01中提到的,簡單IP限制類。 0x01 正文 ...
  • 第一次自己寫博客文章,大家多多指教。寫博客主要記錄一下學習的過程,給初學者提供下參考,也留給自己做備忘。 Slickflow .NET開源工作流-項目轉換 上一篇文章里說了1.2版本的下載,下載解壓後,發現使用的是VS2013創建的項目。可憐我的電腦至今最高版本是VS2010。於是就有了這篇文章。最 ...
  • 第一次自己寫博客文章,大家多多指教。寫博客主要記錄一下學習的過程,給初學者提供下參考,也留給自己做備忘。 Slickflow .NET開源工作流-介紹 這裡摘錄Slickflow官網的介紹: Slickflow工作流引擎,選取BPMN模型作為工作流模型的語義表達,BPMN模型消除技術和業務之間的隔閡 ...
  • <MySQL資料庫操作> 1.創建資料庫. 在MySQL中應用 create database 語句創建資料庫.格式如下: create database db_name; db_name 為資料庫名,必須為合法名稱.規定如下: a.不能與其他資料庫重名. b.名字可以是任意的字母,阿拉伯數字,下劃 ...
  • 變數的可見性(即作用域)和生命期既有區別,又有聯繫。 一個變數在程式的某處沒有可見性,但生命期任然可以存在,比如局部靜態變數的可見性在它所在的函數裡面,在函數外部不可訪問,但是它的生命期確是整個程式的運行期間;而一個變數生命期結束,它也就沒有了可見性,就像局部變數,隨著棧空間的釋放,它也就不存在了, ...
  • WebView提供了在Android應用中展示網頁的強大功能。也是目前Hybird app的大力發展的基礎。作為Android系統的一個非常重要的組件,它提供兩方面的強大的能力:對HTML的解析,佈局和繪製;對JavaScript的解釋和執行。Hybird App的組成是Native+H5,Nati ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...