다음 칼럼에서는 Redis Tutorial 칼럼에서 Redis의 적용 시나리오와 장점, 단점을 소개하겠습니다. 도움이 필요한 친구들에게 도움이 되길 바랍니다!
일반적인 비관계형 데이터베이스인 Redis는 현재 엔터프라이즈급 애플리케이션에서 널리 사용되고 있습니다. 스토리지가 적고 액세스 볼륨이 큰 시나리오에 매우 적합합니다. 모든 데이터는 메모리에 저장되어 데이터에 대한 고속 액세스를 보장합니다. noSQL의 한 종류로서 memcached와 차이점과 장점이 무엇인지 살펴보겠습니다.
MySQL+Memcached의 스토리지 아키텍처는 업계에서 일반적으로 사용되지만, 방문 횟수가 계속 증가함에 따라 그에 따른 많은 문제가 발생합니다.
1. MySQL은 데이터베이스와 테이블을 지속적으로 삭제해야 하며 Memcached도 계속 확장해야 합니다.
2. Memcached와 MySQL 간에 특정 데이터 불일치가 있습니다.
3. Memcached의 적중률이 낮아지는 경향이 있습니다. rate 는 MySQL에 직접 침투하여 데이터베이스를 지원할 수 없게 됩니다.
Redis에 대해 말하면 많은 개발자는 Memcached와 같이 데이터를 직접 저장할 수 있는 비관계형 데이터베이스라는 것만 알고 있습니다. K-V 형태이지만 상대적으로 Memcached와 비교하면 차이점도 많습니다.
1. Redis는 단순한 K-V 형식의 데이터 저장을 지원할 뿐만 아니라 list, set, hash, zset 등의 수집 데이터 저장도 지원합니다.
2. Redis는 실시간 데이터 백업 및 적시 다운타임을 지원합니다.
3. Redis는 데이터 지속성을 지원하며, 메모리에 저장된 데이터를 디스크에 직접 저장할 수 있습니다.
SortedSet, 게시/구독, 트랜잭션.
1. 문자열: 문자열은 가장 간단한 Key-Value 형식으로 저장되는 변수입니다. 여기서 값은 숫자 또는 문자열일 수 있습니다. redisObject가 참조하는 문자열을 기본적으로 Redis 내부에 저장하는 방식으로, 증가, 감소 등의 디지털 연산이 감지되면 자동으로 숫자로 변환되어 계산이 완료됩니다. 저장을 위해 문자열로 변환됩니다.
2. 해시: 해시 저장은 키-값 쌍의 값입니다. 그것이 Key-Hash이고 Hash는 k-v 구조입니다. Memcached를 사용한다면 전체 Hash를 패키징하여 메모리에 저장해야 합니다. 특정 값을 쿼리해야 한다면 전체 Hash를 꺼내서 저장해야 합니다. 그런 다음 해당 값을 찾으십시오. Redis는 명령을 통해 직접 Value를 얻을 수 있으므로 성능이 크게 향상됩니다. 구현 원리: 멤버 수가 적을 때 Redis는 메모리를 절약하기 위해 1차원 배열과 유사한 소형 저장소를 사용합니다. 객체가 많을 경우 HashMap 저장소로 직접 변환됩니다.
3. Set: Set은 정렬되지 않은 자연 중복 제거 세트, 즉 Key-Set입니다. 또한 교차점, 합집합 등 컬렉션을 직접 운영할 수 있는 일련의 방법도 제공하는데, 특히 공통의 친구 찾기 및 공통 관심사를 찾는 기능에 편리합니다. 맨 아래 레이어는 값이 null인 HashMap에 의해 구현됩니다.
4. 목록: 목록은 FIFO 원칙을 따르는 순서가 있고 반복 가능한 컬렉션입니다. 정방향 및 역방향 검색을 지원합니다. List를 통해 최신 답변 등의 기능을 쉽게 얻을 수 있습니다.
5. SortedSet: Java의 TreeSet과 유사하며 정렬 가능한 Set 버전입니다. 또한 우선순위 정렬도 지원되며 이를 달성하기 위해 점수 매개변수가 유지됩니다. 하단 레이어는 주로 HashMap을 사용하여 삽입된 값과 점수 우선 순위 간의 매핑을 유지함으로써 정렬을 구현합니다.
6. 게시/구독: 게시 및 구독, 메시지 대기열 MQ와 유사합니다. 특정 키를 구독하도록 선택할 수 있습니다. 이 키가 일부 메시지를 게시하면 이 키를 구독하는 모든 개체가 이 메시지를 받을 수 있습니다. 주로 채팅과 같은 실시간 메시징 시스템에서 사용될 수 있습니다.
7. 트랜잭션: NoSQL은 트랜잭션을 지원하지 않지만 패키지 실행 기능을 제공합니다. 즉, 이 패키지의 모든 명령을 함께 실행해야 합니다. 또한 이 키가 감지될 경우 특정 키를 잠글 수 있습니다. 명령은 패키징되어 실행되며 변경 사항이 발생하면 직접 롤백됩니다.
Redis는 메모리를 사용하여 저장소를 제공하고 지속성 기능을 통해 데이터를 저장합니다. 그리고 요청에 대한 단일 스레드 작업입니다. 이러한 일련의 기능을 통해 Redis는 매우 마법 같은 기능을 갖게 됩니다.
1. 최신 답변을 찾아보세요.
기존 관계형 데이터베이스를 사용하는 경우 name="" order by time desc 제한이 100인 테이블에서 select *를 사용해야 합니다. 이는 데이터베이스 성능을 소모하지만 Redis를 통해 Redis의 Id를 통해 직접 목록을 생성할 수 있습니다. 길이를 1w로 지정하면 검색이 필요할 때 목록의 마지막 100개 레코드가 직접 출력됩니다.
2. 순위 문제
가장 인기 있는 주제, 게임 순위 등 일반적인 순위 문제는 Redis를 통해 쉽게 얻을 수 있으며 ZRank를 사용하여 직접 얻을 수 있습니다.
3. 만료된 데이터 삭제
Redis는 데이터에 유효한 시간을 추가할 수 있습니다. 유효한 시간이 초과되면 Redis는 해당 데이터를 자동으로 삭제합니다.
위 내용은 Redis의 적용 시나리오, 장점 및 단점에 대한 자세한 설명의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!