婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > 如何高效地向Redis插入大量的數(shù)據(jù)(推薦)

如何高效地向Redis插入大量的數(shù)據(jù)(推薦)

熱門標簽:竹間科技AI電銷機器人 西藏教育智能外呼系統(tǒng)價格 地圖標注如何即時生效 地圖標注費用 最簡單的百度地圖標注 小紅書怎么地圖標注店 百度商家地圖標注怎么做 玄武湖地圖標注 太原營銷外呼系統(tǒng)

最近有個哥們在群里問,有一個日志,里面存的是IP地址(一行一個),如何將這些IP快速導入到Redis中。

我剛開始的建議是Shell+redis客戶端。

今天,查看Redis官檔,發(fā)現(xiàn)文檔的首頁部分(http://www.redis.io/documentation)有一個專門的主題是講述“Redis Mass Insertion”的,才知道自己的建議很low。

官方給出的理由如下:

Using a normal Redis client to perform mass insertion is not a good idea for a few reasons: the naive approach of sending one command after the other is slow because you have to pay for the round trip time for every command. It is possible to use pipelining, but for mass insertion of many records you need to write new commands while you read replies at the same time to make sure you are inserting as fast as possible.

Only a small percentage of clients support non-blocking I/O, and not all the clients are able to parse the replies in an efficient way in order to maximize throughput. For all this reasons the preferred way to mass import data into Redis is to generate a text file containing the Redis protocol, in raw format, in order to call the commands needed to insert the required data.

大意是:

1> 每個redis客戶端命令之間有往返時延。

2> 只要一部分客戶端支持非阻塞I/O。

個人理解是,redis命令從執(zhí)行到結果返回,有一定的時延,即便采用多個redis客戶單并發(fā)插入,也很難提高吞吐量,因為,只有非阻塞I/O只能針對有限個連接操作。

那么如何高效的插入呢?

官方在2.6版本推出了一個新的功能-pipe mode,即將支持Redis協(xié)議的文本文件直接通過pipe導入到服務端。

說來拗口,具體實現(xiàn)步驟如下:

1. 新建一個文本文件,包含redis命令

SET Key0 Value0
SET Key1 Value1
...
SET KeyN ValueN

如果有了原始數(shù)據(jù),其實構造這個文件并不難,譬如shell,python都可以

2. 將這些命令轉化成Redis Protocol。

因為Redis管道功能支持的是Redis Protocol,而不是直接的Redis命令。

如何轉化,可參考后面的腳本。

3. 利用管道插入

cat data.txt | redis-cli --pipe

Shell VS Redis pipe

下面通過測試來具體看看Shell批量導入和Redis pipe之間的效率。

測試思路:分別通過shell腳本和Redis pipe向數(shù)據(jù)庫中插入10萬相同數(shù)據(jù),查看各自所花費的時間。

Shell

腳本如下:

#!/bin/bash
for ((i=0;i100000;i++))
do
echo -en "helloworld" | redis-cli -x set name$i >>redis.log
done

每次插入的值都是helloworld,但鍵不同,name0,name1...name99999。

Redis pipe

Redis pipe會稍微麻煩一點

1> 首先構造redis命令的文本文件

在這里,我選用了python

#!/usr/bin/python
for i in range(100000):
  print 'set name'+str(i),'helloworld'

# python 1.py > redis_commands.txt

# head -2 redis_commands.txt

set name0 helloworld
set name1 helloworld

2> 將這些命令轉化成Redis Protocol

在這里,我利用了github上一個shell腳本,

#!/bin/bash

while read CMD; do
 # each command begins with *{number arguments in command}\r\n
 XS=($CMD); printf "*${#XS[@]}\r\n"
 # for each argument, we append ${length}\r\n{argument}\r\n
 for X in $CMD; do printf "\$${#X}\r\n$X\r\n"; done
done  redis_commands.txt

# sh 20.sh > redis_data.txt

# head -7 redis_data.txt

*3
$3
set
$5
name0
$10
helloworld

至此,數(shù)據(jù)構造完畢。

測試結果

如下:

時間消耗完全不是一個量級的。

最后,來看看pipe的實現(xiàn)原理,

  • redis-cli --pipe tries to send data as fast as possible to the server.
  • At the same time it reads data when available, trying to parse it.
  • Once there is no more data to read from stdin, it sends a special ECHO command with a random 20 bytes string: we are sure this is the latest command sent, and we are sure we can match the reply checking if we receive the same 20 bytes as a bulk reply.
  • Once this special final command is sent, the code receiving replies starts to match replies with this 20 bytes. When the matching reply is reached it can exit with success.

即它會盡可能快的將數(shù)據(jù)發(fā)送到Redis服務端,并盡可能快的讀取并解析數(shù)據(jù)文件中的內容,一旦數(shù)據(jù)文件中的內容讀取完了,它會發(fā)送一個帶有20個字節(jié)的字符串的echo命令,Redis服務端即根據(jù)此命令來確認數(shù)據(jù)已插入完畢。

總結:

后續(xù)有童鞋好奇,構造redis命令的時間和將命令轉化為protocol的時間,這里一并貼下:

[root@mysql-server1 ~]# time python 1.py > redis_commands.txt

real  0m0.110s
user  0m0.070s
sys  0m0.040s
[root@mysql-server1 ~]# time sh 20.sh > redis_data.txt

real  0m7.112s
user  0m5.861s
sys  0m1.255s

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

您可能感興趣的文章:
  • Redis批量刪除KEY的方法

標簽:林芝 贛州 廣東 澳門 揚州 唐山 香港 景德鎮(zhèn)

巨人網(wǎng)絡通訊聲明:本文標題《如何高效地向Redis插入大量的數(shù)據(jù)(推薦)》,本文關鍵詞  如何,高效,地,向,Redis,插入,;如發(fā)現(xiàn)本文內容存在版權問題,煩請?zhí)峁┫嚓P信息告之我們,我們將及時溝通與處理。本站內容系統(tǒng)采集于網(wǎng)絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《如何高效地向Redis插入大量的數(shù)據(jù)(推薦)》相關的同類信息!
  • 本頁收集關于如何高效地向Redis插入大量的數(shù)據(jù)(推薦)的相關信息資訊供網(wǎng)民參考!
  • 推薦文章
    主站蜘蛛池模板: 华阴市| 卢氏县| 抚松县| 贡山| 石棉县| 广灵县| 综艺| 永城市| 梁山县| 娱乐| 广德县| 新民市| 宁阳县| 泸水县| 兖州市| 株洲市| 大冶市| 新河县| 庄浪县| 崇礼县| 岐山县| 汉中市| 沾益县| 淮南市| 开鲁县| 彝良县| 师宗县| 大庆市| 泗洪县| 疏勒县| 西乌| 黄石市| 云林县| 宽甸| 塔城市| 平遥县| 巴彦淖尔市| 滦南县| 武定县| 彭山县| 新乡市|