Hyemi Lee

Hyemi Lee

주니어 개발자의 삽질과 기록

Redis Stream

Stream

  • Stream은 로그 데이터를 처리하게위해 5.0에서 새로 도입된 데이터 타입입니다.
  • 대량의 데이터가 연속적으로 발생할때 처리하기 위해 등장했습니다.
  • 기존 데이터를 수정하지 않고 오직 추가로 발생합니다.
  • 이런 종류의 데이터를 stream or log데이터라고 합니다.

XADD : 데이터 추가

XADD key ID field value [field2 value2...]
XADD sensor-1234 * temperature 98.7


  • ID=* : 명령의 결과를 ID로 리턴한다.

XLEN : 데이터 길이 조회

  • 정확히는 ID개수 조회
XLEN sensor-1234

XRANGE : 데이터 조회

XRANGE key start end [COUNT count]
XRANGE sensor-1234 - +
1) 1) 1538319053569-0
 2) 1) "temperature"
 2) "98.7"
2) 1) 1538319053569-1
 2) 1) "temperature"
 2) "98.8"
XRANGE key 1538319053569 1538319053569


  • start=-, end=+, count로 조회 개수 지정 가능
  • start, end에 특정 id지정 가능

XREAD : 데이터 읽어 오기

XREAD [COUNT count] [BLOCK milliseconds] STREAMS key [key ...] ID [ID ...]
XREAD count 1 STREAMS sensor-1234 1538322045065-0
1) 1) "sensor-1234"
 2) 1) 1) 1538322045065-1
 2) 1) "temperature"
 2) "98.8"
  • count : 읽어올 데이터 개수 지정, 지정하지않으면 모든 데이터를 읽어온다
  • ID : 지정한 ID의 다음 데이터를 읽어온다. 처음 데이터 읽으려면 0으로 지정
XREAD block 5000 STREAMS sensor-1234 $
  • Block : 새 데이터가 들어오기를 기다렸다가 들어오면 읽어온다. 이 때는 ID로 특별히 $를 사용한다.

XDEL, XTRIM : 데이터 삭제

  • XDEL ``` XDEL key ID

XDEL sensor-1234 1538322045065-0

<br>
- XTRIM

XTRIM key MAXLEN [~] count

XTRIM sensor-1234 maxlen 10 ```

  • sensor-1234에 데이터가 100개 있다면 오래된 순으로 90개를 지우고 최신 데이터 10개를 남긴다.
  • 특별 옵션, ~(about) : 대량의 데이터를 신속히 처리해야하는 스트림에서는 처리 지연이 발생하지 않도록 해야한다.
    • 따라서 짧은 시간에 처리할 수 있을 정도의 데이터를 삭제하는 기능이다.
    • 예) sensor-1234에 100만개의 데이터가 있다면 999,990개를 지우는데 시간이 걸린다. 이때는 데이터를 추가하거나 처리될수 없다. 이때 처리 지연이 발생할 수 있다.

Reference

  • http://redisgate.kr/redis/command/streams.php
  • https://redis.io/commands#stream

Tags:

Categories:

Updated:

Share on

Twitter Facebook LinkedIn

You may also enjoy

Study, Object, chapter2&3 presentation

2021年04月20日

chapter03. 역할, 책임, 협력 객체지향 설계란, 올바른 객체에게 올바른 책임을 할당하면서 낮은 결합도와 높은 응집도를 가진 구조를 창조하는 활동이다.

Spring, chatting 프로그램 만들기, Reactive란?

2020年06月16日

Reactive 막힘없이 흘러다니는 data(event)를 통해 사용자에게 자연스러운 응답을 주고 규모 탄력적으로 리소스를 사용하며 실패에 있어서 유연하게 대처한다 모든 지점에서 블럭 되지 않게 하자 oop와 같은 패러다임 모든 것을 비동기적인 data의 strea...

Spring, chatting 프로그램 만들기, websocket

2020年06月16日

채팅 서비스 구현하기 팀원들과 velog를 클론코딩하기로 했다. 큰 도메인은 게시물, 개인페이지였고 팀원은 백엔드 개발자 세명이여서 일 분배가 어려웠다. 따라서 나는 그 동안 구현 해보고 싶었던 채팅 서비스를 구현해서 붙여보기로 했다.