1. 程式人生 > >Redis批量匯入資料的方法

Redis批量匯入資料的方法

有時候,我們需要給redis庫中插入大量的資料,如做效能測試前的準備資料。遇到這種情況時,偶爾可能也會懵逼一下,這裡就給大家介紹一個批量匯入資料的方法。

先準備一個redis protocol的檔案(redis protocol可以參考這裡:https://redis.io/topics/protocol),這裡是用java程式來輸出的,java程式碼如下:

<<RedisBatchTest>>

public class RedisBatchTest {

    public static void main(String[] args) {
        String outputFile = "d:\\temp\\redis_input.txt";
        RedisBatchTest test = new RedisBatchTest();
        test.generateFile(outputFile);

    }

    /**
     * 格式化成輸入字串
     *
     * @param args
     * @return
     */
    private String getString(String key, String value) {
        StringBuilder sb = new StringBuilder();
        sb.append("*3").append("\r\n");
        sb.append("$3").append("\r\n");
        sb.append("SET\r\n");

        sb.append("$").append(key.getBytes().length).append("\r\n");
        sb.append(key).append("\r\n");

        sb.append("$").append(value.getBytes().length).append("\r\n");
        sb.append(value).append("\r\n");

        return sb.toString();
    }

    public void generateFile(String file) {
        
        BufferedWriter w = null;
        String key = null;
        String value = null;
        StringBuilder sb = new StringBuilder();
        try {
            w = new BufferedWriter(new OutputStreamWriter(new FileOutputStream(file), "utf-8"));
            for (int i = 1; i <= 380; i++) {
                key = "test_batch_" + i;
                value = "v_" + i + "註冊即送水電費ServiceTest"; // 這是key對應的value
                sb.append(this.getString(key, value));
                if (i % 10 == 0) {
                    w.write(sb.toString());
                    w.flush();
                    sb.delete(0, sb.length());
                    System.out.println("Current write: " + i);
                }
            }
            
        } catch (Exception e) {
            e.printStackTrace();
        } finally {
            try {
                w.flush();
                w.close();
            } catch (IOException e) {
                e.printStackTrace();
            }

        }
    }

}

執行以上程式碼,就會在d:\\temp目錄下生成一個文字檔案,格式如下:

 

 

以上就是redis protocol格式的檔案了,請上傳到要執行的機器上。然後使用以下命令來執行它:

cat input/redis_input.txt | bin/redis-cli -p 6370 -a yourpasswd –pipe

 

如果執行成功的話,你就可以看到如下資訊了:

 

從以上輸出可以看出,380條數全部插入到redis伺服器上啦。

更詳細的資訊,可以參考:https://redis.io/topics/mass-insert