찾다
데이터 베이스RedisRedis가 멀티스레딩을 도입하는 이유는 무엇입니까?

1. 문제 개요

Redis 6.0 이후 버전에서는 원래 단일 스레드 작업을 사용했던 Redis도 선택적으로 멀티 스레드 모델을 사용하기 시작했습니다. Redis 작가님 정말 대단하신 것 같아요. "진정한 향기의 법칙",

잘 생각해보면 이 문제는 사실 크게 두 가지 질문으로 나눌 수 있습니다:

(1 ) Redis가 애초에 단일 스레드 모델을 선택한 이유는 무엇입니까(단일 스레드의 이점)?

(2) Redis가 6.0 이후에 멀티스레딩을 추가한 이유는 무엇입니까(어떤 경우에는 싱글스레딩에 단점이 있는데 멀티스레딩으로 해결할 수 있음)?

사실 작가가 진향정리에서 벗어나지 못한 것은 아니지만, 시간이 지날수록 원래의 디자인은 확실히 낡아서 변경이 필요한 부분이 많아지네요. 자, 두 가지 질문이 있으니 주의 깊게 분석해 보겠습니다.

2. Redis가 처음에 단일 스레드를 사용한 이유는 단일 스레드이든 다중 스레드이든 모두 Redis의 개발 효율성을 높이기 위한 것입니다. Redis는 메모리 기반 데이터베이스이고 많은 양의 스레드도 처리하기 때문입니다. 외부 네트워크 요청을 여러 번 수행하는 것은 불가피합니다. 다행스럽게도 Redis는 높은 효율성을 보장하기 위해 많은 우수한 메커니즘을 사용합니다. 그렇다면 Redis가 단일 스레드 모드로 설계된 이유는 무엇입니까? 다음과 같이 요약할 수 있습니다.

(1) IO 다중화

Redis의 최상위 디자인을 살펴보겠습니다.

FD는 파일 디스크립터로, 현재 파일이 읽기 가능, 쓰기 가능 또는 비정상인지 여부를 의미합니다. I/O 멀티플렉싱 메커니즘을 사용하여 여러 파일 설명자의 읽기 및 쓰기 가능 상태를 동시에 모니터링합니다.
멀티스레딩 특성을 가지고 있다고 이해하시면 됩니다.

네트워크 요청이 수신되면 메모리에서 빠르게 처리됩니다. 대부분의 작업이 순전히 메모리 기반이므로 처리 속도가 매우 빠릅니다.

즉, 단일 스레드 모드에서는 연결된 네트워크 처리량이 많아도 IO 다중화로 인해 고속 메모리 처리에서는 무시될 수 있습니다.

(2) 높은 유지 관리성

멀티 스레딩 모델은 성능은 좋지만 프로그램 실행 순서에 불확실성이 발생하여 동시 읽기 및 쓰기와 관련된 문제가 발생합니다. 단일 스레드 모드를 사용하면 쉽게 디버깅하고 테스트할 수 있습니다.

(3) 메모리 기반에서는 여전히 싱글 스레드 상태에서 효율성이 높습니다

멀티 스레드에서는 CPU 리소스를 최대한 활용할 수 있지만 Redis의 경우 메모리 기반 속도가 상당히 빨라서 10개를 처리할 수 있습니다. 초당 100,000개의 사용자 요청이 충족되지 않으면 Redis 샤딩 기술을 사용하여 해당 요청을 다른 Redis 서버로 전달할 수 있습니다. 이 쿠킹 방법은 동일한 Redis 서비스에서 많은 멀티스레드 작업을 도입하는 것을 방지합니다.

AOF 백업이 필요한 경우를 제외하고 이 작업은 메모리 기반이므로 기본적으로 I/O 작업이 포함되지 않습니다. 이러한 데이터의 읽기 및 쓰기는 메모리에서만 발생하므로 모든 외부 요청을 처리하기 위해 멀티스레딩 모델을 사용하는 것은 처리 속도가 매우 빠르지 않을 수 있습니다.

이제 우리는 이것이 기본적으로 두 문장으로 요약될 수 있다는 것을 알고 있습니다. 메모리를 기반으로 하고 멀티플렉싱 기술을 사용하면 단일 스레딩이 매우 빠르며 멀티 스레딩의 특성을 보장합니다. 멀티스레딩을 사용할 필요가 없기 때문입니다.

3. 멀티스레딩이 도입된 이유는 무엇인가요?

지금은 싱글스레딩의 장점을 언급했지만, 이제 왜 멀티스레딩을 도입하고 그에 따른 불편함을 극복해야 하는지 이야기하고 싶습니다. 멀티 스레딩의 도입은 Redis의 일부 측면에서 단일 스레딩이 더 이상 장점이 ​​없음을 보여줍니다.

Redis 실행 중 네트워크 읽기 및 쓰기를 위한 읽기/쓰기 시스템 호출이 CPU 시간의 대부분을 차지하기 때문에 네트워크 읽기 및 쓰기를 멀티스레드로 하면 성능이 크게 향상됩니다.

Redis의 멀티스레딩은 네트워크 데이터 읽기 및 쓰기, 프로토콜 구문 분석에만 사용되며 명령 실행은 여전히 ​​단일 스레드입니다. 이렇게 설계한 이유는 Redis가 멀티스레딩으로 인해 복잡해지는 것을 원하지 않고, 키, 루아, 트랜잭션, LPUSH/LPOP 등과 같은 동시성 문제를 제어해야 하기 때문입니다.

Redis는 최신 버전에서 다른 스레드에 의해 비동기적으로 처리될 수 있는 몇 가지 삭제 작업을 추가했습니다. 이는 위에서 언급한 내용입니다

. 이러한 삭제 작업이 필요한 이유는 무엇이며, 다중 스레드 처리가 필요한 이유는 무엇입니까? ?

UNLINKFLUSHALL ASYNCFLUSHDB ASYNC우리는 Redis가 요소를 삭제하기 위해 del 명령을 사용할 수 있다는 것을 알고 있습니다. 요소가 수십 또는 수백 메가바이트를 차지할 수 있는 매우 큰 경우, 이를 위해서는 멀티 스레드 비동기 지원이 필요합니다.

이제 백그라운드에서 삭제가 가능합니다.

위 내용은 Redis가 멀티스레딩을 도입하는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명
이 기사는 亿速云에서 복제됩니다. 침해가 있는 경우 admin@php.cn으로 문의하시기 바랍니다. 삭제
Redis : 기능과 기능을 탐색합니다Redis : 기능과 기능을 탐색합니다Apr 19, 2025 am 12:04 AM

Redis는 고속, 다양성 및 풍부한 데이터 구조로 인해 두드러집니다. 1) Redis는 문자열, 목록, 컬렉션, 해시 및 주문 컬렉션과 같은 데이터 구조를 지원합니다. 2) 메모리를 통해 데이터를 저장하고 RDB 및 AOF 지속성을 지원합니다. 3) Redis 6.0에서 시작하여 멀티 스레드 I/O 작업이 도입되어 동시 동시성 시나리오에서 성능이 향상되었습니다.

Redis는 SQL 또는 NOSQL 데이터베이스입니까? 대답이 설명되었습니다Redis는 SQL 또는 NOSQL 데이터베이스입니까? 대답이 설명되었습니다Apr 18, 2025 am 12:11 AM

redisisclassifiedasanoSqldatabaseBecauseItuseSakey-valuedatamodelinsteadofThraditionalRelationalDatabasemodel.Itoffersspeedandflexibility, makingIdealforreal-timeApplicationsandcaching, butitmaynotbesuitableforscenariosrequiringstrictaintetaintetaintetaintetaintetaintetaintegry

REDIS : 응용 프로그램 성능 및 확장 성 향상REDIS : 응용 프로그램 성능 및 확장 성 향상Apr 17, 2025 am 12:16 AM

Redis는 데이터를 캐싱하여 분산 잠금 및 데이터 지속성을 구현하여 응용 프로그램 성능 및 확장 성을 향상시킵니다. 1) 캐시 데이터 : Redis를 사용하여 데이터 액세스 속도를 향상시키기 위해 자주 액세스하는 데이터를 캐시합니다. 2) 분산 잠금 : Redis를 사용하여 분산 된 잠금 장치를 구현하여 분산 환경에서 작동의 보안을 보장합니다. 3) 데이터 지속성 : 데이터 손실을 방지하기위한 RDB 및 AOF 메커니즘을 통한 데이터 보안을 보장합니다.

Redis : 데이터 모델과 구조 탐색Redis : 데이터 모델과 구조 탐색Apr 16, 2025 am 12:09 AM

Redis의 데이터 모델 및 구조에는 5 가지 주요 유형이 포함됩니다. 1. 문자열 : 텍스트 또는 이진 데이터를 저장하는 데 사용되며 원자 연산을 지원합니다. 2. 목록 : 정렬 된 요소 컬렉션, 대기열 및 스택에 적합합니다. 세트 : 세트 작동을 지원하는 비 순차 고유 요소 세트. 4. 순서 세트 (SortedSet) : 순위에 적합한 점수가있는 고유 한 요소 세트. 5. 해시 테이블 (HASH) : 객체를 저장하는 데 적합한 키 값 쌍 모음.

REDIS : 데이터베이스 접근 방식을 분류합니다REDIS : 데이터베이스 접근 방식을 분류합니다Apr 15, 2025 am 12:06 AM

Redis의 데이터베이스 방법에는 메모리 인 데이터베이스 및 키 값 저장소가 포함됩니다. 1) Redis는 메모리에 데이터를 저장하고 빠르게 읽고 쓰고 있습니다. 2) 키 값 쌍을 사용하여 데이터를 저장하고 캐시 및 NOSQL 데이터베이스에 적합한 목록, 컬렉션, 해시 테이블 및 주문 컬렉션과 같은 복잡한 데이터 구조를 지원합니다.

왜 Redis를 사용합니까? 혜택과 장점왜 Redis를 사용합니까? 혜택과 장점Apr 14, 2025 am 12:07 AM

Redis는 빠른 성능, 풍부한 데이터 구조, 고 가용성 및 확장 성, 지속성 기능 및 광범위한 생태계 지원을 제공하기 때문에 강력한 데이터베이스 솔루션입니다. 1) 매우 빠른 성능 : Redis의 데이터는 메모리에 저장되며 동시성이 높고 대기 시간이 낮은 응용 프로그램에 적합한 빠른 읽기 및 쓰기 속도를 가지고 있습니다. 2) 풍부한 데이터 구조 : 다양한 시나리오에 적합한 목록, 컬렉션 등과 같은 여러 데이터 유형을 지원합니다. 3) 고 가용성 및 확장 성 : 마스터 슬레이브 복제 및 클러스터 모드를 지원하여 고 가용성 및 수평 확장 성을 달성합니다. 4) 지속성 및 데이터 보안 : 데이터 지속성은 RDB 및 AOF를 통해 달성되어 데이터 무결성 및 신뢰성을 보장합니다. 5) 광범위한 생태계 및 지역 사회 지원 : 거대한 생태계와 활동적인 커뮤니티,

NOSQL 이해 : Redis의 주요 기능NOSQL 이해 : Redis의 주요 기능Apr 13, 2025 am 12:17 AM

Redis의 주요 기능에는 속도, 유연성 및 풍부한 데이터 구조 지원이 포함됩니다. 1) 속도 : Redis는 메모리 내 데이터베이스이며, 읽기 및 쓰기 작업은 거의 순간적이며 캐시 및 세션 관리에 적합합니다. 2) 유연성 : 복잡한 데이터 처리에 적합한 문자열, 목록, 컬렉션 등과 같은 여러 데이터 구조를 지원합니다. 3) 데이터 구조 지원 : 다양한 비즈니스 요구에 적합한 문자열, 목록, 컬렉션, 해시 테이블 등을 제공합니다.

REDIS : 기본 기능을 식별합니다REDIS : 기본 기능을 식별합니다Apr 12, 2025 am 12:01 AM

Redis의 핵심 기능은 고성능 인 메모리 데이터 저장 및 처리 시스템입니다. 1) 고속 데이터 액세스 : Redis는 메모리에 데이터를 저장하고 마이크로 초 수준 읽기 및 쓰기 속도를 제공합니다. 2) 풍부한 데이터 구조 : 문자열, 목록, 컬렉션 등을 지원하며 다양한 응용 프로그램 시나리오에 적응합니다. 3) 지속성 : RDB 및 AOF를 통해 디스크에 데이터를 지속하십시오. 4) 구독 게시 : 메시지 대기열 또는 실시간 통신 시스템에서 사용할 수 있습니다.

See all articles

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

AI Hentai를 무료로 생성하십시오.

뜨거운 도구

mPDF

mPDF

mPDF는 UTF-8로 인코딩된 HTML에서 PDF 파일을 생성할 수 있는 PHP 라이브러리입니다. 원저자인 Ian Back은 자신의 웹 사이트에서 "즉시" PDF 파일을 출력하고 다양한 언어를 처리하기 위해 mPDF를 작성했습니다. HTML2FPDF와 같은 원본 스크립트보다 유니코드 글꼴을 사용할 때 속도가 느리고 더 큰 파일을 생성하지만 CSS 스타일 등을 지원하고 많은 개선 사항이 있습니다. RTL(아랍어, 히브리어), CJK(중국어, 일본어, 한국어)를 포함한 거의 모든 언어를 지원합니다. 중첩된 블록 수준 요소(예: P, DIV)를 지원합니다.

SublimeText3 영어 버전

SublimeText3 영어 버전

권장 사항: Win 버전, 코드 프롬프트 지원!

SublimeText3 중국어 버전

SublimeText3 중국어 버전

중국어 버전, 사용하기 매우 쉽습니다.

Dreamweaver Mac版

Dreamweaver Mac版

시각적 웹 개발 도구

VSCode Windows 64비트 다운로드

VSCode Windows 64비트 다운로드

Microsoft에서 출시한 강력한 무료 IDE 편집기