Redis 튜토리얼(1): Redis 소개
1. 소개:
지난 몇 년간 NoSQL 데이터베이스는 높은 동시성, 대용량 데이터 저장 솔루션의 대명사가 되었고, 이에 상응하는 제품도 비가 내린 뒤 버섯처럼 솟아올랐습니다. 하지만 Redis, MongoDB, BerkeleyDB, CouchDB 등 많은 제품 중에서 눈에 띄는 제품은 소수에 불과합니다. 각 제품마다 특성이 다르기 때문에 적용 시나리오에도 특정 차이점이 있습니다.
1) BerkeleyDB는 매우 인기 있는 오픈 소스 임베디드 데이터베이스입니다. 예를 들어, BerkeleyDB는 Oracle에 인수되기 전에 MySQL의 스토리지 엔진으로 사용되었으며, 이 제품은 동시성 확장성이 뛰어나고 트랜잭션 및 중첩 트랜잭션을 지원하며 대용량 데이터를 저장하는 등 중요한 기능을 제공할 것으로 예상됩니다. 실시간 데이터 저장에 있어 활용 가치가 매우 높습니다. 그러나 이 제품의 라이센스는 GPL이므로 모든 경우에 무료로 사용할 수는 없다는 점을 지적해야 합니다.
2) MongoDB는 BerkeleyDB와 달리 Oriented-Document 데이터베이스 서버로 정의되며, 이 데이터베이스는 독립적으로 실행될 수 있으며 다른 관계형 데이터베이스 서버와 마찬가지로 관련 데이터 서비스를 제공합니다. 이 제품의 공식 문서를 통해 MongoDB가 주로 동시성이 높은 포럼이나 블로그 웹사이트에 적합하다는 것을 알 수 있습니다. 이러한 웹사이트의 주요 특징은 높은 동시 방문, 더 많은 읽기 및 더 적은 쓰기, 많은 양의 데이터, 단순한 논리적 관계입니다. 및 문서를 기본 데이터 소스로 사용합니다. BerkeleyDB와 마찬가지로 이 제품의 라이센스는 GPL입니다.
3) 일반적인 NoSQL 데이터베이스 서버인 Redis는 BerkeleyDB에 비해 서비스 프로그램으로 자체 서버 호스트에서 독립적으로 실행할 수 있습니다. 많은 사람들은 Redis를 키/값 데이터베이스 서버로 간주하지만 현재 버전에서는 Redis가 키/값 외에도 List, Hash, Set 및 Ordered Set과 같은 데이터 구조도 지원합니다. , 그래서 용도도 더 넓습니다. 이러한 오해에 대해 Redis 공식 웹사이트에서도 이에 상응하는 해명을 제공했습니다. 위의 두 제품과 다르게 Redis의 라이선스는 Apache 라이선스로 현재 완전 무료입니다.
4) memcached, 데이터 캐싱 서버. 이 제품에 대한 설명이 여기에 나와 있는 이유는 무엇입니까? 매우 간단합니다. 사용법 측면에서 Redis와 가장 유사하다고 생각하기 때문입니다. 결국 이것은 Redis에 대한 기술 블로그 시리즈이므로 이를 고려하여 이 두 제품을 간략하게 비교해 보겠습니다. 먼저, 이들 간의 가장 큰 차이점에 대해 말씀드리자면, Memcached는 데이터 캐싱 서비스만을 제공하며, 서버가 다운되면 이전에 메모리에 캐시되어 있던 데이터는 모두 사라지게 되므로 어떠한 형태의 캐싱도 제공하지 않는다는 것을 알 수 있습니다. 데이터 지속성 기능은 Redis가 제공하는 기능입니다. 또한 Redis는 Hash 및 Set과 같은 더욱 풍부한 데이터 저장 구조를 제공합니다. 유사점은 두 가지입니다. 하나는 완전히 무료라는 것이고, 다른 하나는 그들이 제공하는 명령 형식이 매우 유사하다는 것입니다.
2. Redis의 장점:
1) Redis는 다른 NoSQL 제품에 비해 사용이 매우 간편하므로 유사한 제품을 사용해 본 경험이 있는 개발자라면 Redis를 사용하여 다음 작업을 수행할 수 있습니다. 하루나 이틀, 심지어 몇 시간 안에 나만의 플랫폼을 구축하세요.
2) 많은 일반적인 문제를 해결하는 동시에 인덱싱 엔진, 통계 순위, 메시지 대기열 서비스 등과 같은 일부 개인화된 문제에 대한 관련 솔루션도 제공합니다.
3. 현재 버전의 Redis의 주요 문제점:
1) 정식 버전에서는 Windows 플랫폼 지원이 없으며, 출시된 정식 버전은 Unix 계열과 MacOSX만 지원합니다. 플랫폼.
2) 클러스터 지원은 제공되지 않으나, 공식 홈페이지에 따르면 이 기능은 버전 2.6에 추가될 예정이라고 합니다.
3) 발행/구독 기능에서는 마스터가 다운되면 슬레이브가 자동으로 마스터로 승격되지 않습니다.
4. 관계형 데이터베이스와의 비교:
Redis의 현재 버전(2.4.7)에서는 5가지 데이터 유형을 지원하며, 그 중 문자열 유형만 Key-Value 구조로 간주할 수 있고 다른 데이터 유형은 다음과 같습니다. 각각의 특성에 적용되는 애플리케이션 시나리오를 다루고 있으며, 이 시리즈의 후반부 블로그에서 구체적인 세부 사항을 설명할 것입니다.
관계형 데이터베이스에 비해 Redis는 상대적으로 단순한 저장 구조로 인해 복잡한 논리적 관계를 제대로 지원하지 못합니다. 그러나 Redis에 적용할 수 있는 시나리오에서는 이를 통해 효율성이 크게 향상됩니다. 그럼에도 불구하고 Redis는 동일한 연결에서 다른 데이터베이스를 열도록 선택할 수 있는 것과 같이 데이터베이스가 가져야 하는 몇 가지 기본 개념을 제공합니다. 그러나 차이점은 Redis의 데이터베이스 이름은 기본적으로 숫자로 지정된다는 것입니다. 열린 데이터베이스는 0입니다. 프로그램이 실행되는 동안 데이터베이스를 전환하려는 경우 Redis select 명령을 사용하여 select 1과 같은 다른 데이터베이스를 열 수 있습니다. 나중에 기본 데이터베이스로 다시 전환하려면 select 0을 실행하면 됩니다.
데이터 저장 측면에서 Redis는 기존 NoSQL 데이터베이스의 주류 아이디어를 따릅니다. 즉, Key는 데이터 검색을 위한 고유 식별자로 간단히 관계형 데이터베이스의 인덱스 키로 이해하면 됩니다. 값은 데이터 저장소로 사용됩니다. 기본 개체인 각 값에는 연결된 키가 있으며, 이는 인덱스의 물리적 데이터가 데이터 테이블에 저장되는 위치와 같습니다. Redis에서 Value는 Json, XML, 직렬화된 객체의 바이트 스트림 등 모든 형식의 데이터를 저장하는 데 사용되는 바이너리 바이트 스트림으로 간주되므로 RDB의 BLOB 유형 필드로 상상할 수도 있습니다. 데이터 쿼리를 수행할 때 쿼리 조건으로 Key만 사용할 수 있다는 것을 알 수 있습니다. 물론 Redis에서 제공하는 일부 기술을 적용하여 Value를 다른 데이터의 키로 사용할 수도 있습니다. 다음 블로그를 소개합니다.
5. 메모리 데이터를 유지하는 방법:
기본적으로 Redis는 현재 데이터베이스의 데이터 수정 횟수를 참조하고 특정 임계값에 도달하면 다음의 스냅샷을 저장합니다. 디스크의 데이터베이스에서는 구성 파일을 통해 임계값을 설정할 수 있습니다. 일반적으로 Redis가 정기적으로 저장하도록 설정할 수도 있습니다. 예를 들어 1,000개 이상의 주요 데이터가 수정되면 Redis는 60초마다 데이터 지속성 작업을 수행합니다. 기본 설정은 데이터 수정이 9개 이하인 경우 Redis가 15분마다 지속된다는 것입니다.
위에서 언급한 솔루션을 보면 이 방법을 채택하면 Redis의 런타임 효율성이 매우 효율적이라는 것을 알 수 있습니다. 새로운 데이터 수정이 발생할 때마다 메모리에 캐시된 데이터만 수정되며, 이러한 변경 사항은 디스크에 즉시 유지되지 않으므로 대부분의 수정 작업에서 디스크 IO가 방지됩니다. 그러나 상황에는 양면이 있는 경우가 많습니다. 이 방법을 사용하면 효율성은 향상되지만 데이터 신뢰성은 떨어집니다. 메모리 스냅샷이 디스크에 유지되기 전에 Redis가 위치한 서버가 다운되면 디스크에 기록되지 않은 수정된 데이터가 모두 손실됩니다. 데이터의 높은 신뢰성을 보장하기 위해 Redis는 또 다른 데이터 지속성 메커니즘인 추가 모드도 제공합니다. Redis 서버가 이러한 방식으로 구성되면 데이터 수정이 발생할 때마다 즉시 디스크에 유지됩니다.
위 내용은 Redis Tutorial(1): Redis 소개의 내용입니다. 더 많은 관련 내용은 PHP 중국어 홈페이지(www.php.cn)를 참고해주세요!

핫 AI 도구

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

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

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

Video Face Swap
완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

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

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

뜨거운 주제











Redis Cluster Mode는 Sharding을 통해 Redis 인스턴스를 여러 서버에 배포하여 확장 성 및 가용성을 향상시킵니다. 시공 단계는 다음과 같습니다. 포트가 다른 홀수 redis 인스턴스를 만듭니다. 3 개의 센티넬 인스턴스를 만들고, Redis 인스턴스 및 장애 조치를 모니터링합니다. Sentinel 구성 파일 구성, Redis 인스턴스 정보 및 장애 조치 설정 모니터링 추가; Redis 인스턴스 구성 파일 구성, 클러스터 모드 활성화 및 클러스터 정보 파일 경로를 지정합니다. 각 redis 인스턴스의 정보를 포함하는 Nodes.conf 파일을 작성합니다. 클러스터를 시작하고 Create 명령을 실행하여 클러스터를 작성하고 복제본 수를 지정하십시오. 클러스터에 로그인하여 클러스터 정보 명령을 실행하여 클러스터 상태를 확인하십시오. 만들다

Redis 데이터를 지우는 방법 : Flushall 명령을 사용하여 모든 키 값을 지우십시오. FlushDB 명령을 사용하여 현재 선택한 데이터베이스의 키 값을 지우십시오. 선택을 사용하여 데이터베이스를 전환 한 다음 FlushDB를 사용하여 여러 데이터베이스를 지우십시오. del 명령을 사용하여 특정 키를 삭제하십시오. Redis-Cli 도구를 사용하여 데이터를 지우십시오.

Redis의 대기열을 읽으려면 대기열 이름을 얻고 LPOP 명령을 사용하여 요소를 읽고 빈 큐를 처리해야합니다. 특정 단계는 다음과 같습니다. 대기열 이름 가져 오기 : "큐 :"와 같은 "대기열 : my-queue"의 접두사로 이름을 지정하십시오. LPOP 명령을 사용하십시오. 빈 대기열 처리 : 대기열이 비어 있으면 LPOP이 NIL을 반환하고 요소를 읽기 전에 대기열이 존재하는지 확인할 수 있습니다.

CentOS 시스템에서는 Redis 구성 파일을 수정하거나 Redis 명령을 사용하여 악의적 인 스크립트가 너무 많은 리소스를 소비하지 못하게하여 LUA 스크립트의 실행 시간을 제한 할 수 있습니다. 방법 1 : Redis 구성 파일을 수정하고 Redis 구성 파일을 찾으십시오. Redis 구성 파일은 일반적으로 /etc/redis/redis.conf에 있습니다. 구성 파일 편집 : 텍스트 편집기 (예 : VI 또는 Nano)를 사용하여 구성 파일을 엽니 다. Sudovi/etc/redis/redis.conf LUA 스크립트 실행 시간 제한을 설정 : 구성 파일에서 다음 줄을 추가 또는 수정하여 LUA 스크립트의 최대 실행 시간을 설정하십시오 (Unit : Milliseconds).

REDIS 데이터 만료 전략에는 두 가지 유형이 있습니다. 정기 삭제 : 만료 된 기간 캡-프리브-컨트 컨트 및 만료 된 시간 캡-프레임 딜레이 매개 변수를 통해 설정할 수있는 만료 된 키를 삭제하기위한주기 스캔. LAZY DELETION : 키를 읽거나 쓰는 경우에만 삭제가 만료 된 키를 확인하십시오. 그것들은 게으른 불쾌한 말입니다. 게으른 유발, 게으른 게으른 expire, Lazyfree Lazy-user-del 매개 변수를 통해 설정할 수 있습니다.

Redis Command Line 도구 (Redis-Cli)를 사용하여 다음 단계를 통해 Redis를 관리하고 작동하십시오. 서버에 연결하고 주소와 포트를 지정하십시오. 명령 이름과 매개 변수를 사용하여 서버에 명령을 보냅니다. 도움말 명령을 사용하여 특정 명령에 대한 도움말 정보를 봅니다. 종금 명령을 사용하여 명령 줄 도구를 종료하십시오.

Redis Counter는 Redis Key-Value Pair 스토리지를 사용하여 다음 단계를 포함하여 계산 작업을 구현하는 메커니즘입니다. 카운터 키 생성, 카운트 증가, 카운트 감소, 카운트 재설정 및 카운트 얻기. Redis 카운터의 장점에는 빠른 속도, 높은 동시성, 내구성 및 단순성 및 사용 편의성이 포함됩니다. 사용자 액세스 계산, 실시간 메트릭 추적, 게임 점수 및 순위 및 주문 처리 계산과 같은 시나리오에서 사용할 수 있습니다.

Debian Systems에서 ReadDir 시스템 호출은 디렉토리 내용을 읽는 데 사용됩니다. 성능이 좋지 않은 경우 다음과 같은 최적화 전략을 시도해보십시오. 디렉토리 파일 수를 단순화하십시오. 대규모 디렉토리를 가능한 한 여러 소규모 디렉토리로 나누어 읽기마다 처리 된 항목 수를 줄입니다. 디렉토리 컨텐츠 캐싱 활성화 : 캐시 메커니즘을 구축하고 정기적으로 캐시를 업데이트하거나 디렉토리 컨텐츠가 변경 될 때 캐시를 업데이트하며 readDir로 자주 호출을 줄입니다. 메모리 캐시 (예 : Memcached 또는 Redis) 또는 로컬 캐시 (예 : 파일 또는 데이터베이스)를 고려할 수 있습니다. 효율적인 데이터 구조 채택 : 디렉토리 트래버스를 직접 구현하는 경우 디렉토리 정보를 저장하고 액세스하기 위해보다 효율적인 데이터 구조 (예 : 선형 검색 대신 해시 테이블)를 선택하십시오.
