Redis客戶端開發包:Jedis學習-入門

来源:http://www.cnblogs.com/chenpi/archive/2016/07/18/5680358.html
-Advertisement-
Play Games

添加Jedis依賴 我們可以使用以下三種方式來添加Jedis依賴。 1、下載jar文件 從http://search.maven.org/下載最近的jedis包和Apache Commons Pool 2 2.0依賴包。 2、從源碼中構建 以下方式會構建最新的Jedis版本。 首先、克隆GitHub ...


添加Jedis依賴

我們可以使用以下三種方式來添加Jedis依賴。

1、下載jar文件

從http://search.maven.org/下載最近的jedis包Apache Commons Pool 2 2.0依賴包。

2、從源碼中構建

以下方式會構建最新的Jedis版本。

首先、克隆GitHub項目

很簡單,在命令行輸入git clone git://github.com/xetorthio/jedis.git命令即可。

然後、使用maven構建項目

在使用maven打包之前,需要先通過單元測試,我們可以運行make package命令完成單元測試和打包工作。

3、配置maven依賴

Jedis通過Sonatype,被髮布為一個Maven依賴,我們可以在pom.xml文件中添加以下xml片段來配置Jedis依賴

<dependency>
    <groupId>redis.clients</groupId>
    <artifactId>jedis</artifactId>
    <version>2.8.0</version>
    <type>jar</type>
    <scope>compile</scope>
</dependency>

添加完後,在工程的maven依賴庫中可以看到以下兩個jar文件:

基本使用示例

在多線程環境中使用Jedis

你不應該在不同的線程中使用同一個Jedis對象實例,否則會遇到各種奇怪的錯誤。

同樣的,針對每個線程都創建一個Jedis實例也不是很合適,因為這意味著會有許多sockets和connections,也會造成奇怪的錯誤。

一個Jedis實例存線上程安全問題,為了避免這個問題,我們應該使用Jedis池(JedisPool),它是線程安全的。使用JedisPool,我們不僅可以避免那些奇怪的錯誤,還能取得良好的性能。

可以使用以下代碼片段初始化一個JedisPool:

JedisPool pool = new JedisPool(new JedisPoolConfig(), "localhost");

JedisPoolConfig對象包含了一些預設的連接池配置,我們可以通過查看其構造方法瞭解其具體預設配置信息,如下代碼:

  public JedisPoolConfig() {
    // defaults to make your life with connection pool easier :)
    setTestWhileIdle(true);
    setMinEvictableIdleTimeMillis(60000);
    setTimeBetweenEvictionRunsMillis(30000);
    setNumTestsPerEvictionRun(-1);
  }

另外,JedisPool是基於Commons Pool 2的,所以我們也可以瞭解一下Commons Pool的配置,詳見http://commons.apache.org/proper/commons-pool/apidocs/org/apache/commons/pool2/impl/GenericObjectPoolConfig.html。

下麵給出一個完整的例子,註意要先啟動redis服務端:

package cn.edu.hdu.jedisdemo;

import java.util.Set;

import redis.clients.jedis.Jedis;
import redis.clients.jedis.JedisPool;
import redis.clients.jedis.JedisPoolConfig;

public class App {
    public static void main(String[] args) {
        JedisPool pool = new JedisPool(new JedisPoolConfig(), "localhost");
        // / Jedis implements Closable. Hence, the jedis instance will be
        // auto-closed after the last statement.
        try (Jedis jedis = pool.getResource()) {
            // / ... do stuff here ... for example
            jedis.set("foo", "bar");
            String foobar = jedis.get("foo");
            jedis.zadd("sose", 0, "car");
            jedis.zadd("sose", 0, "bike");
            Set<String> sose = jedis.zrange("sose", 0, -1);
            System.out.println(foobar);
            System.out.println(sose);
        }
        // / ... when closing your application:
        pool.close();
    }
}

如果你的JAVA版本不支持try-with-resource語法,我們可以使用Jedis.close()

Jedis jedis = null;
try {
  jedis = pool.getResource();
  /// ... do stuff here ... for example
  jedis.set("foo", "bar");
  String foobar = jedis.get("foo");
  jedis.zadd("sose", 0, "car"); jedis.zadd("sose", 0, "bike"); 
  Set<String> sose = jedis.zrange("sose", 0, -1);
} finally {
  if (jedis != null) {
    jedis.close();
  }
}
/// ... when closing your application:
pool.destroy();

主從配置

主伺服器負責接收寫數據請求,並且將數據改變複製給從伺服器,來保持數據一致性。

從伺服器(不一定是必須的)負責接受讀數據請求,來減輕主伺服器的壓力。

主從同步的過程

建立主從關係後,slave 會建立和 master 的連接,然後發送 sync 命令。master會啟動一個後臺進程,將資料庫快照保存到文件中,同時master主進程開始收集寫命令並緩存起來。當後臺完成寫文件後,master伺服器會將快照文件發給slave伺服器,slave伺服器會將快照文件恢復到slave的記憶體資料庫上。完成快照恢復後,master將緩存的寫命令轉發給slave,slave更新記憶體資料庫。然後,後續master的寫命令會通過開始建立的連接發送給slave來完成數據同步。

主從關係的特點

master伺服器下麵可以有多個slave伺服器,slave伺服器下麵也可以有多個slave伺服器,可以形成樹狀結構

主從複製不會阻塞master伺服器,但會阻塞slave伺服器

啟用主從關係

我們可以通過以下兩種方式啟用主從關係:

1、通過各個redis伺服器的配置文件來配置主從關係

slaveof  192.168.1.35 6379  # 指定master主伺服器的ip和埠

優缺點:簡單,但是配置文件是在伺服器啟動時載入的,所以伺服器啟動後就不能線上修改了。

2、通過調用slaveOf方法,傳入ip地址和埠號,

jedis.slaveOf("localhost", 6379);  //  if the master is on the same PC which runs your code
jedis.slaveOf("192.168.1.35", 6379); 

優點:可以線上修改redis伺服器的主從關係

關閉主從關係,提升一個從伺服器為主伺服器

當一個主伺服器宕機的時候,我們希望能將一個從伺服器升級為主伺服器。

為此,我們需要先關閉原先的主從關係,然後(假定我們有多個從伺服器),將其餘從伺服器配置到新的主伺服器上。

slave1jedis.slaveofNoOne();    //取消主伺服器關聯,自己成為主伺服器
slave2jedis.slaveof("192.168.1.36", 6379);    //指定主伺服器的ip和埠

 

參考資料:

https://github.com/xetorthio/jedis/wiki

http://www.tuicool.com/articles/Uruyemf


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

-Advertisement-
Play Games
更多相關文章
  • 看到TreeSet先從最基礎的去瞭解他,他是一個類,他所在的位置是java.util包中。 我們可以看一看他的繼承架構圖: 該類實現的介面: 1TreeSet案例: TreeSet是一個有序集合,TreeSet中的元素將按照升序排列,預設是按照自然排序進行排列,意味著TreeSet中的元素要實現Co ...
  • 1.TreeSet原理: /* * TreeSet存儲對象的時候, 可以排序, 但是需要指定排序的演算法 * * Integer能排序(有預設順序), String能排序(有預設順序), 自定義的類存儲的時候出現異常(沒有順序) * * 如果想把自定義類的對象存入TreeSet進行排序, 那麼必須實現 ...
  • 一、在 Spring Config 文件中,在 <bean> 元素的 scope 屬性里設置 Bean 的作用域。預設為 singleton ,單例的。 二、在不引入 spring-web-4.0.0.RELEASE.jar 包的情況下,scope 屬性只有兩個值:singleton 和 proto ...
  • 1. Critical Warning (332012): Synopsys Design Constraints File file not found: 'led_test.sdc'. A Synopsys Design Constraints File is required by the T... ...
  • 首先下載所需軟體: Vc2015:https://www.microsoft.com/zh-CN/download/details.aspx?id=48145 Vc2012:http://www.microsoft.com/zh-CN/download/details.aspx?id=30679 A ...
  • 今天下了好大的雨。 這兩天總算把第二章過了。第二章主要是 指針。 算是重點吧,這也是C語言的特色啊,直接訪問物理存儲。 重點: 指針就是一個存放它指向變數地址的變數,好繞口。 區分*在定義是與引用是的作用。 區分*、&的不同。 指針是可以指向另一個指針的。 數組名也是一個存放地址,換句話說,也可以當 ...
  • 一、在 Spring IOC 容器中 Bean 之間存在繼承和依賴關係。 需要註意的是,這個繼承和依賴指的是 bean 的配置之間的關係,而不是指實際意義上類與類之間的繼承與依賴,它們不是一個概念。 二、Bean 之間的繼承關係。 1.被繼承的 ban 稱為父 bean,繼承這個父 bean 的 b ...
  • 1.php利用mysqldump備份資料庫,代碼如下: 2.通過bat運行以上php文件,bat文件內容如下: 其中: e:/wamp/php5.4.44/php.exe :php安裝路徑; e:/wamp/backup.php :要運行的php文件; zzy :要備份的資料庫; 30 :備份數據保 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...