主頁 >  其他 > 你不知道的redis五-redis進階,第三方jar沒有封裝的命令我們該怎么執行?

你不知道的redis五-redis進階,第三方jar沒有封裝的命令我們該怎么執行?

2020-10-14 13:01:44 其他

目錄

一、Pipelin模式介紹

1、redis的通常使用方式

2、Pipeline模式

3、性能對比

二、Redis事物

1、事務命令

2、事務例外

三、redis發布與訂閱

1、Redis發布訂閱常用命令

2、性能測驗

3、應用場景

四、鍵的遷移

1、move

2、dump

3、migrate

五、自定義命令封裝

六、鍵全量遍歷

1、keys

2、漸進式遍歷 scan

3、scan 和keys對比

4、其他遍歷命令


在redis入門章節時,已經給大家介紹了redis的基本操作指令,今天對redis的進階操作給大家介紹一下,以及對于jedis和redisTemplate等工具包沒有封裝的命令我們該如何使用?相信大家讀了本篇對redis的整體會有更深的認知,

一、Pipelin模式介紹

1、redis的通常使用方式

大多數情況下,我們都會通過請求-相應機制去操作redis,使用這種模式的步驟為

  1. 獲得jedis實體
  2. 發送redis命令
  3. 由于redis是單執行緒的,所以處理完上一個指令之后才會進行執行該命令,

整個互動流程如下

2、Pipeline模式

然而使用Pipeline 模式,客戶端可以一次性的發送多個命令,無需等待服務端回傳,這樣就大大的減少了網路往返時間,提高了系統性能,

pipeline是多條命令的組合,使用PIPELINE 可以解決網路開銷的問題,原理也非常簡單,流程如下, 將多個指令打包后,一次性提交到Redis, 網路通信只有一次

3、性能對比

網路

延遲

Pipeline

Pipeline

本機

1300

1414

114

內網服務器

1222ms

1532ms

310ms

異地機房

90910ms

92 000ms

1090ms

可以看到,redis的延遲主要出現在網路請求的IO次數上,因此我們在使用redis的時候,盡量減少網路IO次數,通過pipeline的方式將多個指令封裝在一個命令里執行,

二、Redis事物

redis的簡單事務是將一組需要一起執行的命令放到multi和exec兩個命令之間,其中multi代表事務開始,exec代表事務結束

1、事務命令

multi:事務開始

exec:提交事務

watch:事務監控

WATCH命令可以監控一個或多個鍵,一旦其中有一個鍵被修改(或洗掉),之后的事務就不會執行,監控一直持續到

discard:停止事務

在執行exec之前執行該命令,提交事務會失敗,執行的命令會進行回滾

127.0.0.1:6379> multi     //開始事務

OK

127.0.0.1:6379> sadd tt 1   //業務操作

QUEUED

127.0.0.1:6379> DISCARD   //停止事務

OK

127.0.0.1:6379> exec   //提交事務

(error) ERR EXEC without MULTI   //報不存在事務例外

127.0.0.1:6379> get tt  //獲取不到物件

(nil)

127.0.0.1:6379>

2、事務例外

redis支持事務,但他屬于弱事務,中間的一些例外可能會導致事務失效,

1、命令錯誤,語法不正確,導致事務不能正常結束

127.0.0.1:6379> multi   //開始事務

OK

127.0.0.1:6379> set aa 123  //業務操作

QUEUED

127.0.0.1:6379> sett bb 124  //命令錯誤

(error) ERR unknown command 'sett'

127.0.0.1:6379> exec 

(error) EXECABORT Transaction discarded because of  previous errors.  //提交事務例外

127.0.0.1:6379> get aa  //查詢不到資料

(nil)

127.0.0.1:6379>

2、運行錯誤,語法正確,但型別錯誤,事務可以正常結束

127.0.0.1:6379> multi

OK

127.0.0.1:6379> set t 1   //業務操作1

QUEUED

127.0.0.1:6379> sadd t 1  //業務操作2

QUEUED

127.0.0.1:6379> set t 2  //業務操作3

QUEUED

127.0.0.1:6379> exec

1) OK

2) (error) WRONGTYPE Operation against a key holding the wrong kind of value  //型別例外

3) OK

127.0.0.1:6379> get t  //可以獲取到t

"2"

127.0.0.1:6379>

三、redis發布與訂閱

redis提供了“發布、訂閱”模式的訊息機制,其中訊息訂閱者與發布者不直接通信,發布者向指定的頻道(channel)發布訊息,訂閱該頻道的每個客戶端都可以接收到訊息

1、Redis發布訂閱常用命令

命令含義
publish channel發布訊息
subscribe channel訂閱訊息
pubsub numsub channel查看訂閱數
unsubscribe channel取消訂閱
psubscribe ch*按模式訂閱和取消訂閱

2、性能測驗

見我的另一個博文:redis 發布訂閱 性能測驗

3、應用場景

redis主要提供發布訊息、訂閱頻道、取消訂閱以及按照模式訂閱和取消訂閱,和很多專業的訊息佇列(kafka rabbitmq),redis的發布訂閱顯得很lower, 比如無法實作訊息規程和回溯, 但就是簡單,如果能滿足應用場景,用這個也可以

  1. 訂閱號、公眾號、微博關注、郵件訂閱系統等
  2. 即使通信系統
  3. 群聊部落系統(微信群)

四、鍵的遷移

鍵遷移大家可能用的不是很多,因為一般都是使用redis主從同步,不過對于我們做資料統計分析使用的時候,可能會使用到,比如用戶標簽,為了避免key批量洗掉導致的redis雪崩,一般都是通過一個計算使用的redis和一個最終業務使用的redis,通過將計算時用的redis里的鍵值通過遷移的方式一個一個的更新到業務redis中,使其對業務沖擊最小化,

1、move

move指令將redis一個庫中的資料遷移到另外一個庫中,

move key db  //reids有16個庫, 編號為0-15
set name DK;  move name 5 //遷移到第6個庫
elect 5 ;//資料庫切換到第6個庫,
get name  可以取到james1

如果key在目標資料庫中已存在,那么什么也不會發生,這種模式不建議在生產環境使用,在同一個reids里可以玩

2、dump

Redis DUMP 命令用于將key給序列化 ,并回傳被序列化的值,用于匯入到其他服務中

一般通過dump命令匯出,使用restore命令匯入,

1,A服務器上

set name james;
dump name;       //  得到"\x00\x05james\b\x001\x82;f\"DhJ"

2,B服務器上

restore name 0 "\x00\x05james\b\x001\x82;f\"DhJ"    //0代表沒有過期時間
get name           //回傳james

3、migrate

migrate用于在Redis實體間進行資料遷移,實際上migrate命令是將dump、restore、del三個命令進行組合,從而簡化了操作流程,

migrate命令具有原子性,從Redis 3.0.6版本后已經支持遷移多個鍵的功能,migrate命令的資料傳輸直接在源Redis和目標Redis上完成,目標Redis完成restore后會發送OK給源Redis,

migrate

192.168.42.112

6379

name

0

1000

copy

replace

指令

要遷移的目標IP

遷移鍵值

目標庫

超時時間

遷移后不洗掉原鍵

不管目標庫是不存在test鍵都遷移成功

比如:把111上的name鍵值遷移到112上的redis

192.168.42.111:6379> migrate 192.168.42.112 6379 name 0 1000 copy

五、自定義命令封裝

當我們使用jedis或者jdbctemplate時,想執行鍵遷移的指令的時候,發現根本沒有給我們封裝相關指令,這個時候我們該怎么辦呢?除了框架幫我們封裝的方法外,我們自己也可以通過反射的方式進行命令的封裝,主要步驟如下

  1. 建立Connection鏈接,使用Connection連接Redis
  2. 通過反射獲取Connection中的sendCommand方法(protected Connection sendCommand(Command cmd, String... args)),
  3. 呼叫connection的sendCommand方法,第二個引數為執行的命令(比如set,get,client等),第三個引數為命令的引數,可以看到ProtocolCommand這個列舉物件包含了redis的所有指令,即所有的指令都可以通過這個物件獲取到,并封裝執行
  4. 執行invoke方法,并且按照redis的指令封裝引數
  5. 獲取Redis的命令執行結果
package com.james.cache.jedis;

import redis.clients.jedis.Connection;
import redis.clients.jedis.Protocol;

import java.io.IOException;
import java.lang.reflect.InvocationTargetException;
import java.lang.reflect.Method;

/**
 * @Auther: DK
 * @Date: 2020/10/11 23:17
 * @Description:
 */
public class RedisKeyMove {

    public static void main(String[] args) throws IOException {
        //1.使用Connection連接Redis
        try (Connection connection = new Connection("10.1.253.188", 6379)) {
            // 2. 通過反射獲取Connection中的sendCommand方法(protected Connection sendCommand(Command cmd, String... args)),
            Method method = Connection.class.getDeclaredMethod("sendCommand", Protocol.Command.class, String[].class);
            method.setAccessible(true); // 設定可以訪問private和protected方法
            // 3. 呼叫connection的sendCommand方法,第二個引數為執行的命令(比如set,get,client等),第三個引數為命令的引數,
            // 3.1 該命令最終對應redis中為: set test-key test-value
            method.invoke(connection, Protocol.Command.MIGRATE,
                    new String[] {"10.1.253.69", "6379", "name", "0", "1000", "copy"});
            // 4.獲取Redis的命令執行結果
            System.out.println(connection.getBulkReply());
        } catch (NoSuchMethodException e) {
            e.printStackTrace();
        } catch (IllegalAccessException e) {
            e.printStackTrace();
        } catch (InvocationTargetException e) {
            e.printStackTrace();
        }
    }
}

六、鍵全量遍歷

1、keys

指令含義
keys *回傳所有的鍵, *匹配任意字符多個字符
keys *y以結尾的鍵
keys n*e以n開頭以e結尾,回傳name
keys n?me?問號代表只匹配一個字符 回傳name,全域匹配
keys n?m* 回傳name
keys [j,l]*回傳以j l開頭的所有鍵 keys [j]ames 全量匹配james

考慮到是單執行緒,使用改命令會阻塞執行緒, 在生產環境不建議使用,鍵多可能會阻塞,

2、漸進式遍歷 scan

1,初始化資料

mset n1 1 n2 2 n3 3 n4 4 n5 5 n6 6 n7 7 n8 8 n9 9 n10 10 n11 11 n12 12 n13 13

2,遍歷匹配

scan 0 match n* count 5    匹配以n開頭的鍵,最大是取5條,第一次scan 0開始

第二次從游標4096開始取20個以n開頭的鍵,相當于一頁一頁的取當最后回傳0時,鍵被取完,

3、scan 和keys對比

  1. 通過游標分布進行的,不會阻塞執行緒;
  2. 提供 limit 引數,可以控制每次回傳結果的最大條數,limit 不準,回傳的結果可多可少;
  3. 同 keys 一樣,Scan也提供模式匹配功能;
  4. 服務器不需要為游標保存狀態,游標的唯一狀態就是 scan 回傳給客戶端的游標整數;
  5. scan回傳的結果可能會有重復,需要客戶端去重復;
  6. scan遍歷的程序中如果有資料修改,改動后的資料能不能遍歷到是不確定的;
  7. 單次回傳的結果是空的并不意味著遍歷結束,而要看回傳的游標值是否為零;

4、其他遍歷命令

SCAN 命令用于迭代當前資料庫中的資料庫鍵,

SSCAN 命令用于迭代集合鍵中的元素,

HSCAN 命令用于迭代哈希鍵中的鍵值對,

ZSCAN 命令用于迭代有序集合中的元素(包括元素成員和元素分值),

用法和scan一樣

轉載請註明出處,本文鏈接:https://www.uj5u.com/qita/171930.html

標籤:其他

上一篇:mysql

下一篇:蒙特卡洛樹搜索 MCTS 入門

標籤雲
其他(157675) Python(38076) JavaScript(25376) Java(17977) C(15215) 區塊鏈(8255) C#(7972) AI(7469) 爪哇(7425) MySQL(7132) html(6777) 基礎類(6313) sql(6102) 熊猫(6058) PHP(5869) 数组(5741) R(5409) Linux(5327) 反应(5209) 腳本語言(PerlPython)(5129) 非技術區(4971) Android(4554) 数据框(4311) css(4259) 节点.js(4032) C語言(3288) json(3245) 列表(3129) 扑(3119) C++語言(3117) 安卓(2998) 打字稿(2995) VBA(2789) Java相關(2746) 疑難問題(2699) 细绳(2522) 單片機工控(2479) iOS(2429) ASP.NET(2402) MongoDB(2323) 麻木的(2285) 正则表达式(2254) 字典(2211) 循环(2198) 迅速(2185) 擅长(2169) 镖(2155) 功能(1967) .NET技术(1958) Web開發(1951) python-3.x(1918) HtmlCss(1915) 弹簧靴(1913) C++(1909) xml(1889) PostgreSQL(1872) .NETCore(1853) 谷歌表格(1846) Unity3D(1843) for循环(1842)

熱門瀏覽
  • 網閘典型架構簡述

    網閘架構一般分為兩種:三主機的三系統架構網閘和雙主機的2+1架構網閘。 三主機架構分別為內端機、外端機和仲裁機。三機無論從軟體和硬體上均各自獨立。首先從硬體上來看,三機都用各自獨立的主板、記憶體及存盤設備。從軟體上來看,三機有各自獨立的作業系統。這樣能達到完全的三機獨立。對于“2+1”系統,“2”分為 ......

    uj5u.com 2020-09-10 02:00:44 more
  • 如何從xshell上傳檔案到centos linux虛擬機里

    如何從xshell上傳檔案到centos linux虛擬機里及:虛擬機CentOs下執行 yum -y install lrzsz命令,出現錯誤:鏡像無法找到軟體包 前言 一、安裝lrzsz步驟 二、上傳檔案 三、遇到的問題及解決方案 總結 前言 提示:其實很簡單,往虛擬機上安裝一個上傳檔案的工具 ......

    uj5u.com 2020-09-10 02:00:47 more
  • 一、SQLMAP入門

    一、SQLMAP入門 1、判斷是否存在注入 sqlmap.py -u 網址/id=1 id=1不可缺少。當注入點后面的引數大于兩個時。需要加雙引號, sqlmap.py -u "網址/id=1&uid=1" 2、判斷文本中的請求是否存在注入 從文本中加載http請求,SQLMAP可以從一個文本檔案中 ......

    uj5u.com 2020-09-10 02:00:50 more
  • Metasploit 簡單使用教程

    metasploit 簡單使用教程 浩先生, 2020-08-28 16:18:25 分類專欄: kail 網路安全 linux 文章標簽: linux資訊安全 編輯 著作權 metasploit 使用教程 前言 一、Metasploit是什么? 二、準備作業 三、具體步驟 前言 Msfconsole ......

    uj5u.com 2020-09-10 02:00:53 more
  • 游戲逆向之驅動層與用戶層通訊

    驅動層代碼: #pragma once #include <ntifs.h> #define add_code CTL_CODE(FILE_DEVICE_UNKNOWN,0x800,METHOD_BUFFERED,FILE_ANY_ACCESS) /* 更多游戲逆向視頻www.yxfzedu.com ......

    uj5u.com 2020-09-10 02:00:56 more
  • 北斗電力時鐘(北斗授時服務器)讓網路資料更精準

    北斗電力時鐘(北斗授時服務器)讓網路資料更精準 北斗電力時鐘(北斗授時服務器)讓網路資料更精準 京準電子科技官微——ahjzsz 近幾年,資訊技術的得了快速發展,互聯網在逐漸普及,其在人們生活和生產中都得到了廣泛應用,并且取得了不錯的應用效果。計算機網路資訊在電力系統中的應用,一方面使電力系統的運行 ......

    uj5u.com 2020-09-10 02:01:03 more
  • 【CTF】CTFHub 技能樹 彩蛋 writeup

    ?碎碎念 CTFHub:https://www.ctfhub.com/ 筆者入門CTF時時剛開始刷的是bugku的舊平臺,后來才有了CTFHub。 感覺不論是網頁UI設計,還是題目質量,賽事跟蹤,工具軟體都做得很不錯。 而且因為獨到的金幣制度的確讓人有一種想去刷題賺金幣的感覺。 個人還是非常喜歡這個 ......

    uj5u.com 2020-09-10 02:04:05 more
  • 02windows基礎操作

    我學到了一下幾點 Windows系統目錄結構與滲透的作用 常見Windows的服務詳解 Windows埠詳解 常用的Windows注冊表詳解 hacker DOS命令詳解(net user / type /md /rd/ dir /cd /net use copy、批處理 等) 利用dos命令制作 ......

    uj5u.com 2020-09-10 02:04:18 more
  • 03.Linux基礎操作

    我學到了以下幾點 01Linux系統介紹02系統安裝,密碼啊破解03Linux常用命令04LAMP 01LINUX windows: win03 8 12 16 19 配置不繁瑣 Linux:redhat,centos(紅帽社區版),Ubuntu server,suse unix:金融機構,證券,銀 ......

    uj5u.com 2020-09-10 02:04:30 more
  • 05HTML

    01HTML介紹 02頭部標簽講解03基礎標簽講解04表單標簽講解 HTML前段語言 js1.了解代碼2.根據代碼 懂得挖掘漏洞 (POST注入/XSS漏洞上傳)3.黑帽seo 白帽seo 客戶網站被黑帽植入劫持代碼如何處理4.熟悉html表單 <html><head><title>TDK標題,描述 ......

    uj5u.com 2020-09-10 02:04:36 more
最新发布
  • 2023年最新微信小程式抓包教程

    01 開門見山 隔一個月發一篇文章,不過分。 首先回顧一下《微信系結手機號資料庫被脫庫事件》,我也是第一時間得知了這個訊息,然后跟蹤了整件事情的經過。下面是這起事件的相關截圖以及近日流出的一萬條資料樣本: 個人認為這件事也沒什么,還不如關注一下之前45億快遞資料查詢渠道疑似在近日復活的訊息。 訊息是 ......

    uj5u.com 2023-04-20 08:48:24 more
  • web3 產品介紹:metamask 錢包 使用最多的瀏覽器插件錢包

    Metamask錢包是一種基于區塊鏈技術的數字貨幣錢包,它允許用戶在安全、便捷的環境下管理自己的加密資產。Metamask錢包是以太坊生態系統中最流行的錢包之一,它具有易于使用、安全性高和功能強大等優點。 本文將詳細介紹Metamask錢包的功能和使用方法。 一、 Metamask錢包的功能 數字資 ......

    uj5u.com 2023-04-20 08:47:46 more
  • vulnhub_Earth

    前言 靶機地址->>>vulnhub_Earth 攻擊機ip:192.168.20.121 靶機ip:192.168.20.122 參考文章 https://www.cnblogs.com/Jing-X/archive/2022/04/03/16097695.html https://www.cnb ......

    uj5u.com 2023-04-20 07:46:20 more
  • 從4k到42k,軟體測驗工程師的漲薪史,給我看哭了

    清明節一過,盲猜大家已經無心上班,在數著日子準備過五一,但一想到銀行卡里的余額……瞬間心情就不美麗了。最近,2023年高校畢業生就業調查顯示,本科畢業月平均起薪為5825元。調查一出,便有很多同學表示自己又被平均了。看著這一資料,不免讓人想到前不久中國青年報的一項調查:近六成大學生認為畢業10年內會 ......

    uj5u.com 2023-04-20 07:44:00 more
  • 最新版本 Stable Diffusion 開源 AI 繪畫工具之中文自動提詞篇

    🎈 標簽生成器 由于輸入正向提示詞 prompt 和反向提示詞 negative prompt 都是使用英文,所以對學習母語的我們非常不友好 使用網址:https://tinygeeker.github.io/p/ai-prompt-generator 這個網址是為了讓大家在使用 AI 繪畫的時候 ......

    uj5u.com 2023-04-20 07:43:36 more
  • 漫談前端自動化測驗演進之路及測驗工具分析

    隨著前端技術的不斷發展和應用程式的日益復雜,前端自動化測驗也在不斷演進。隨著 Web 應用程式變得越來越復雜,自動化測驗的需求也越來越高。如今,自動化測驗已經成為 Web 應用程式開發程序中不可或缺的一部分,它們可以幫助開發人員更快地發現和修復錯誤,提高應用程式的性能和可靠性。 ......

    uj5u.com 2023-04-20 07:43:16 more
  • CANN開發實踐:4個DVPP記憶體問題的典型案例解讀

    摘要:由于DVPP媒體資料處理功能對存放輸入、輸出資料的記憶體有更高的要求(例如,記憶體首地址128位元組對齊),因此需呼叫專用的記憶體申請介面,那么本期就分享幾個關于DVPP記憶體問題的典型案例,并給出原因分析及解決方法。 本文分享自華為云社區《FAQ_DVPP記憶體問題案例》,作者:昇騰CANN。 DVPP ......

    uj5u.com 2023-04-20 07:43:03 more
  • msf學習

    msf學習 以kali自帶的msf為例 一、msf核心模塊與功能 msf模塊都放在/usr/share/metasploit-framework/modules目錄下 1、auxiliary 輔助模塊,輔助滲透(埠掃描、登錄密碼爆破、漏洞驗證等) 2、encoders 編碼器模塊,主要包含各種編碼 ......

    uj5u.com 2023-04-20 07:42:59 more
  • Halcon軟體安裝與界面簡介

    1. 下載Halcon17版本到到本地 2. 雙擊安裝包后 3. 步驟如下 1.2 Halcon軟體安裝 界面分為四大塊 1. Halcon的五個助手 1) 影像采集助手:與相機連接,設定相機引數,采集影像 2) 標定助手:九點標定或是其它的標定,生成標定檔案及內參外參,可以將像素單位轉換為長度單位 ......

    uj5u.com 2023-04-20 07:42:17 more
  • 在MacOS下使用Unity3D開發游戲

    第一次發博客,先發一下我的游戲開發環境吧。 去年2月份買了一臺MacBookPro2021 M1pro(以下簡稱mbp),這一年來一直在用mbp開發游戲。我大致分享一下我的開發工具以及使用體驗。 1、Unity 官網鏈接: https://unity.cn/releases 我一般使用的Apple ......

    uj5u.com 2023-04-20 07:40:19 more