Redis 데이터 구조의 사용 시나리오 소개

王林
풀어 주다: 2021-03-09 09:09:43
앞으로
2264명이 탐색했습니다.

Redis 데이터 구조의 사용 시나리오 소개

Redis 데이터베이스에는 문자열, 해시 사전, 목록, 집합 및 정렬된 집합의 다섯 가지 데이터 구조가 있습니다.

이 다섯 가지 데이터 구조에는 서로 다른 사용 시나리오가 있습니다. 아래에서 사용 시나리오를 소개하겠습니다.

1. String

String 데이터 구조는 간단한 Key-Value 유형입니다. 값은 String일 뿐만 아니라 숫자일 수도 있습니다. (숫자 유형이 Long으로 표현될 수 있는 경우 인코딩은 정수 유형이고 나머지는 유형입니다.) sdshdr에 문자열로 저장됩니다. String 유형을 사용하면 Memcached의 현재 기능을 완전히 실현하고 더욱 효율적으로 사용할 수 있습니다. 또한 Redis의 예약된 지속성(RDB 모드 또는 AOF 모드 선택 가능), 작업 로그, 복제 및 기타 기능을 즐길 수 있습니다. Memcached와 동일한 get, set, incr, decr 및 기타 작업을 제공하는 것 외에도 redis는 다음 작업도 제공합니다:

1.LEN niushuai:O(1)获取字符串长度
2.APPEND niushuai redis:往字符串 append 内容,而且采用智能分配内存(每次2倍)
3.设置和获取字符串的某一段内容
4.设置及获取字符串的某一位(bit)
5.批量设置一系列字符串的内容
6.原子计数器
7.GETSET 命令的妙用,请于清空旧值的同时设置一个新值,配合原子计数器使用
로그인 후 복사

2, Hash

Memcached에서는 일부 구조화된 정보를 HashMap에 패키지하는 경우가 많습니다. 클라이언트에서는 사용자의 별명, 나이, 성별 등과 같은 문자열 값(일반적으로 JSON 형식)으로 저장됩니다. 이때, 항목 중 하나를 수정해야 할 때 보통 문자열(JSON)을 꺼내서 역직렬화하고 특정 항목의 값을 수정한 후 문자열(JSON)로 직렬화하여 저장해야 하는 경우가 많습니다. 다시. 많은 작업을 수행하기 위해 단순히 속성을 수정하는 것은 매우 비용이 많이 들고 동시 작업이 가능한 일부 상황(예: 두 개의 동시 작업에서 기간을 수정해야 함)에는 적합하지 않습니다. Redis의 해시 구조를 사용하면 데이터베이스의 속성을 업데이트하는 것처럼 특정 속성 값만 수정할 수 있습니다. (사용자 속성 저장, 읽기, 수정)

3. List

List는 단순히 연결 목록입니다(redis는 List를 구현하기 위해 이중 연결 목록을 사용합니다). 구조. List 구조를 사용하면 최신 뉴스 순위(예: Sina Blog의 TimeLine)와 같은 기능을 쉽게 구현할 수 있습니다. List의 또 다른 응용 프로그램은 메시지 대기열입니다. List의 Push 작업을 사용하여 작업을 List에 저장하면 작업자 스레드가 PoP 작업을 사용하여 실행할 작업을 꺼낼 수 있습니다. Redis는 또한 목록에 있는 특정 요소 세그먼트를 작동하기 위한 API를 제공합니다. 목록에 있는 특정 요소 세그먼트를 직접 쿼리하고 삭제할 수 있습니다.

(학습 영상 공유: redis 데이터베이스 튜토리얼)

4. Set

Set은 반복되지 않는 값들의 집합이라는 개념입니다. 일부 집단 데이터는 Redis에서 제공하는 Set 데이터 구조를 사용하여 저장할 수 있습니다. 예를 들어 Weibo 애플리케이션에서는 사용자의 모든 팔로어를 컬렉션에 저장할 수 있고 모든 팬을 컬렉션에 저장할 수 있습니다. Redis는 매우 사용자 친화적이며 컬렉션에 대한 교집합, 합집합, 차이 등의 연산을 제공하므로 위의 모든 컬렉션 연산에 대해 공통 관심, 공통 선호도, 2급 친구 등의 기능을 구현하는 것이 매우 편리할 수 있습니다. 다른 명령을 사용하여 결과를 클라이언트에 반환할지 아니면 새 컬렉션에 저장할지 선택할 수도 있습니다.

1.共同好友、二度好友
2.利用唯一性,可以统计访问网站的所有独立 IP
3.好友推荐的时候,根据 tag 求交集,大于某个 threshold 就可以推荐
로그인 후 복사

5. Sorted Set

Set와 비교하여 Sorted Set은 세트의 요소에 가중치 매개변수 점수를 추가하므로 세트의 요소를 저장하는 것과 같이 점수에 따라 순서대로 배열할 수 있습니다. Sorted Set의 경우, 그 설정 값은 동급생의 학생 번호, 점수는 시험 점수가 될 수 있으므로 데이터가 세트에 삽입되면 이미 자연 정렬이 수행되었습니다. 또한 Sorted Set을 사용하여 가중치가 적용된 대기열을 만들 수도 있습니다. 예를 들어 일반 메시지의 점수는 1이고 중요한 메시지의 점수는 2입니다. 그런 다음 작업자 스레드는 작업을 얻기 위해 아픈 순서를 역순으로 선택할 수 있습니다. 작업. 중요한 작업의 우선순위를 정하세요.

2. 다른 Redis 기능의 사용 시나리오

1. 구독-게시 시스템

Pub/Sub는 말 그대로 게시(Publish) 및 구독(Subscribe)을 의미합니다. Redis에서는 특정 키 값을 설정할 수 있습니다. 구독. 키 값에 대한 메시지가 게시되면 해당 메시지를 구독하는 모든 클라이언트가 해당 메시지를 받게 됩니다. 이 기능의 가장 확실한 용도는 실시간 메시징 시스템입니다.

2. 트랜잭션

NoSql이 트랜잭션을 지원하지 않는다고 누가 말했습니까? redis 트랜잭션은 엄격한 ACID 트랜잭션(예: EXEC를 사용하여 실행하기 위해 제출된 일련의 명령, 실행 중에 서버가 다운됨)을 제공하지 않습니다. 일부 명령이 실행되고 나머지는 실행되지 않음), 이 트랜잭션은 여전히 ​​명령 패키징 및 실행의 기본 기능을 제공합니다(서버에 문제가 없는 경우 일련의 명령이 함께 실행되는 것을 보장할 수 있음). 순서대로 진행되며 중간에 다른 명령이 삽입되고 실행됩니다. Redis는 감시 기능도 제공합니다. 이 과정에서 감시 값이 수정되면 트랜잭션이 발견되어 실행이 거부됩니다.

관련 권장 사항: redis 데이터베이스 튜토리얼

위 내용은 Redis 데이터 구조의 사용 시나리오 소개의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

관련 라벨:
원천:csdn.net
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿