inflearn logo
강의

Khóa học

Chia sẻ kiến thức

Cách giải quyết các vấn đề đồng thời bằng hệ thống kiểm kê

So sánh Mysql và Redis

Redis를 이용한 방식이 MySQL을 이용한 방식보다 느리지 않나요?

Đã giải quyết

1135

shef

22 câu hỏi đã được viết

2

제가 생각하기로는 Redis를 이용한 방식은

서버 -> Redis

서버 -> MySQL

이렇게 두 번 접근하게 되니 네트워크 타는 시간 때문에 당연히 더 느릴 것이라고 생각했거든요

비관적 락을 이용한다면

서버 -> MySQL

이렇게 바로 접근한 후에 lock이 풀릴 때까지 기다렸다가 바로 작업을 수행하니 더 빠르지 않나요?

spring java 동시성

Câu trả lời 3

3

169developer9973

morib 님 안녕하세요.

첫째로 hjoo 님께서 말씀해주신것처럼 redis 는 inmemory db 이기때문에 작업속도가 굉장히 빠릅니다.

그렇기에 대부분의 경우에는 문제가 되지 않습니다.

두번째로는 비관적락을 사용하는경우에 A 커넥션이 먼저 진입하고 락을잡게되면 이후의 커넥션들은 대기를 하게됩니다.

이때 락을 잡고있는 트랜잭션의 작업이 길어지게된다면 커넥션의 수가 모자라게되는 문제가 생길 수 있습니다.

이런상황이 생기면 데이터베이스의 쿼리가 느려지게 되고 서비스가 느려지게 됩니다.

반면에 redis 를 활용하게 되면 커넥션이 대기하는 상황이 없어지기때문에 이런문제점을 예방할 수 있습니다.

감사합니다 :)

3

hjoo

단순하게 데이터를 가져오고 가공하는 절차로만 보면 그럴 수 있는데, 물리적인 속도와 특성 차이가 있습니다.
Redis 는 읽고 쓰기를 디스크가 아니고 메모리에 직접 하기 때문에 속도가 월등이 빠릅니다. 대신 서버 내리면 휘발되구요. 그래서 레디스타고 mysql 타고 해도 특별히 느리지 않은 경우가 많습니다.

https://goodgid.github.io/Redis/

 

0

169developer9973

hjoo 님 답변 달아주셔서 감사합니다 :)

1

shef

두 분 다 답변 남겨주셔서 감사합니다 ! 커넥션 수가 모자라는 문제는 생각하지 못했네요 :)

레디선 테스트코드에서 채널이름은 없어도 되는건가요?

0

66

2

낙관적 락을 사용할 떄 차이점

0

147

2

동시성 검증 코드에 관한 문의

0

108

2

단일연산

0

86

2

낙관적락vs. 레디스락

0

121

2

안녕하세요. 레디슨 질문있습니다..!!

0

76

2

@Lock(OPTIMISTIC)이 필요한 이유

0

104

2

get_lock 의 timeout이 3000초 이던데 너무 긴거 아닌가요?

0

142

2

DataSource Hikari 사용 이유

0

159

2

saveAndFlush 사용 이유 문의

0

121

3

비관적 락 VS 네임드 락

0

174

3

application.yaml 에 redis 정보

0

102

2

왜 클래스 이름에 Facade 가 붙나요?

0

194

2

@Transactional 으로 인한 동시성 문제 발생 원인이 궁금합니다.

0

226

2

@modifying 이용한 동시성 제어

0

179

2

DB락과 분산락

0

279

2

NamedLock 테스트 실패

0

191

2

테스트에서 트랜잭션 어노테이션 질문 있습니다.

0

183

2

optimistic Lock 재시도 질문입니다.

0

245

2

낙관적 락 테스트 실패

0

256

2

오류?

0

1643

4

LettureLockStockFacadeTest에서 오류가 발생합니다.

1

273

2

Pessimistic Lock 전체 테스트 오류 문의

0

380

3

비관적 락 vs 레디스(Lettuce)락 비교 관련 질문

0

470

2