Skip to content

매수 매도 체결 로직에 의해 redis pub sub이 정상적으로 동작하지 않는 문제

JIN edited this page Dec 4, 2024 · 1 revision

🧑🏻 작성자

⚙️ Web BE ⚙️ Web BE
김진 이시은

💣 문제 상황

다른 로직에서 한국투자 Open API WebSocket에 정상적으로 구독 요청 및 해제를 하기 위해 서버가 재실행될 때마다 Redis를 비워주는 작업을 했다.

그러나 매수/매도 체결 로직은 서버가 실행될 때 DB에서 종목 코드를 가져와 구독 요청을 하는 로직이었기 때문에, 서버가 실행될 때마다 Redis를 비우고 구독 요청을 하게 되면 아래와 같은 상황이 발생한다.

image

사진에서 사용한 예시처럼, DB에 005930이라는 종목 코드에 대한 매수/매도 체결 요청이 있었다고 가정했을 때, 서버가 하나씩 실행될 때마다 Redis 내 데이터를 삭제하는 로직이 실행되어 여전히 세 개의 서버가 동일한 종목을 구독하게 되는 상황이 발생했다.

✨ 해결 과정

Deploy에 사용하는 YAML 파일 코드를 확인해보니, 가장 먼저 deploy되는 서버에서 Redis Docker를 실행하는 코드를 발견했다.

서버 코드 내에서 Redis 내 데이터를 지우지 않고, Redis Docker를 실행하는 시점에 데이터를 지우면 서버가 deploy될 때마다 Redis 내 데이터를 삭제하지 않아 우리의 의도대로 동작할 수 있다는 생각을 했다.

if [ "${{ matrix.app.name }}" = "be-1" ]; then
  docker run -d \
  --name redis \
  --network network \
  -p port:port \
  -v redis_data:/data \
  redis:latest redis-server --appendonly yes
            
  docker exec redis redis-cli EVAL "local keys = redis.call('keys', 'connections:*') for i=1,#keys do redis.call('del', keys[i]) end" 0
fi

코드를 위와 같이 수정해, Redis가 실행되는 시점에서만 불필요한 데이터를 지울 수 있어 우리의 의도대로 동작하는 것을 확인할 수 있었다.

👓 참고 자료

📜 개발 일지

⚠️ 트러블 슈팅

❗ 규칙

🗒️ 기록

기획
회의록
데일리스크럼
그룹 멘토링
그룹 회고

😲 개별 멘토링

고동우
김진
서산
이시은
박진명
Clone this wiki locally