10가지 Redis 사용 팁
Redis는 현재 기술 커뮤니티에서 매우 인기가 있습니다. Redis는 Antirez의 소규모 개인 프로젝트에서 인 메모리 데이터 스토리지의 업계 표준이 되기까지 먼 길을 걸어왔습니다. 결과적인 모범 사례 세트를 통해 대부분의 사람들은 Redis를 올바르게 사용할 수 있습니다.
1. KEYS 사용 중지 *
좋습니다. 이 명령에 도전하여 이 글을 시작하는 것은 좋은 방법이 아닐 수도 있지만 가장 중요한 포인트일 수 있습니다. 우리는 redis 인스턴스의 통계를 살펴볼 때 핵심 정보가 명확하게 표시되도록 "KEYS *" 명령을 빠르게 입력할 때가 많습니다.
프로그래밍 관점에서 우리는 다음과 같은 의사 코드를 작성하는 경향이 있습니다.
for key in'keys *': doAllTheThings()
그러나 1300만 개의 키가 있으면 실행 속도가 느려집니다. KEYS 명령의 시간 복잡도는 O(n)(여기서 n은 반환할 키 수)이므로 이 명령의 복잡도는 데이터베이스 크기에 따라 달라집니다. 그리고 이 작업을 실행하는 동안에는 인스턴스에서 다른 명령을 실행할 수 없습니다.
대체 명령으로 SCAN을 살펴보세요. 보다 사용자 친화적인 방식으로 수행할 수 있습니다. SCAN은 증분 반복으로 데이터베이스를 스캔합니다. 이 작업은 커서의 반복자를 기반으로 수행되므로 언제든지 원하는 대로 중지하거나 계속할 수 있습니다.
2. Redis 속도를 저하시키는 원인을 찾아보세요
Redis에는 자세한 로그가 없기 때문에 Redis 인스턴스 내부에서 어떤 작업이 수행되는지 파악하기가 매우 어렵습니다. 다행히 Redis는 다음과 같은 명령 통계 도구를 제공합니다.
127.0.0.1:6379> INFO commandstats # Commandstats cmdstat_get:calls=78,usec=608,usec_per_call=7.79 cmdstat_setex:calls=5,usec=71,usec_per_call=14.20 cmdstat_keys:calls=2,usec=42,usec_per_call=21.00 cmdstat_info:calls=10,usec=1931,usec_per_call=193.10
이 도구를 통해 명령이 실행된 횟수, 명령을 실행하는 데 걸린 시간(밀리초) 등 모든 명령 통계의 스냅샷을 볼 수 있습니다. 명령(각 명령의 총 시간 및 평균 시간)
CONFIG RESETSTAT 명령을 실행하여 재설정하면 완전히 새로운 통계 결과를 얻을 수 있습니다.
3. Redis의 아버지인 Salvatore는 Redis-Benchmark 결과를 참고로 사용합니다. "GET/SET 명령을 실행하여 Redis를 테스트하는 것은 자동차의 거울을 청소할 때 Ferrari의 앞유리 와이퍼의 효과를 테스트하는 것과 같습니다. 비오는 날." 많은 사람들이 저를 찾아와 Redis-Benchmark 통계가 최적 결과보다 낮은 이유를 알고 싶어합니다. 하지만 다양한 실제 상황을 고려해야 합니다.
예:
- 어떤 클라이언트 실행 환경에 의해 제한될 수 있나요?
- 버전 번호가 같은가요?
- 테스트 환경의 성능이 애플리케이션이 실행될 환경과 일치합니까?
- Redis-Benchmark의 테스트 결과는 Redis-Server가 비정상적인 상태에서 실행되지 않도록 하는 벤치마크 포인트를 제공하지만, 이를 실제 "스트레스 테스트"로 받아들여서는 안 됩니다. 스트레스 테스트는 애플리케이션이 실행되는 방식을 반영해야 하며 프로덕션과 최대한 유사한 환경이 필요합니다.
4. 해시가 최선의 선택입니다
우아한 방식으로 해시를 소개하세요. 해시는 당신에게 전례 없는 경험을 선사할 것입니다. 이전에 다음과 유사한 키 구조를 많이 보았습니다.
foo:first_name foo:last_name foo:address
위 예에서 foo는 사용자의 사용자 이름일 수 있으며 그 안의 각 항목은 별도의 키입니다. 이렇게 하면 오류와 불필요한 키의 여지가 늘어납니다. 대신 해시를 사용하면 키가 하나만 필요하다는 사실에 놀랄 것입니다.
127.0.0.1:6379> HSET foo first_name 'Joe' (integer) 1 127.0.0.1:6379> HSET foo last_name 'Engel' (integer) 1 127.0.0.1:6379> HSET foo address '1 Fanatical Pl' (integer) 1 127.0.0.1:6379> HGETALL foo 1) 'first_name' 2) 'Joe' 3) 'last_name' 4) 'Engel' 5) 'address' 6) '1 Fanatical Pl' 127.0.0.1:6379> HGET foo first_name 'Joe'
5. 키 값의 생존 시간을 설정하세요.
가능하면 키 시간 초과를 활용하세요. 좋은 예는 임시 인증 키와 같은 것을 저장하는 것입니다. 인증 키를 조회할 때(예: OAUTH) 일반적으로 시간 초과가 발생합니다.
이런 식으로 키를 설정할 때 동일한 시간 초과로 설정하면 Redis가 자동으로 키를 지웁니다! 더 이상 모든 키를 탐색하기 위해 KEYS *를 사용할 필요가 없습니다. 얼마나 편리합니까?
6. 적절한 재활용 전략을 선택하세요
키 지우기에 관해 이야기했으니 이제 재활용 전략에 대해 이야기해 보겠습니다. Redis 인스턴스 공간이 가득 차면 일부 키 회수를 시도합니다. 사용량에 따라 키에 시간 초과를 설정한 경우 휘발성-lru 전략을 사용하는 것이 좋습니다.
그러나 캐시와 유사한 것을 실행 중이고 키에 대한 시간 초과 메커니즘을 설정하지 않은 경우 allkeys-lru 재활용 메커니즘 사용을 고려할 수 있습니다.
7. 데이터가 중요하다면 Try/Except를 사용하세요
중요한 데이터를 Redis 인스턴스에 넣을 수 있는지 확인해야 한다면 try/except 블록에 넣는 것이 좋습니다. 거의 모든 Redis 클라이언트는 "보내고 잊어버리기" 전략을 채택하므로 키가 실제로 Redis 데이터베이스에 있는지 여부를 고려해야 하는 경우가 많습니다.
Redis 명령에 try/expect를 넣는 것의 복잡성에 대해서는 이 문서에서 다루지 않습니다. 그렇게 하면 중요한 데이터가 있어야 할 위치에 배치될 수 있다는 점만 알면 됩니다.
8. 인스턴스를 소진하지 마세요
가능하면 여러 Redis 인스턴스의 작업 부하를 분산하세요. 버전 3.0.0부터 Redis는 클러스터를 지원합니다. Redis 클러스터를 사용하면 키 범위를 기반으로 마스터/슬레이브 모드를 포함하는 일부 키를 분리할 수 있습니다. 클러스터링 뒤에 숨은 완전한 "마법"은 여기에서 찾을 수 있습니다.
하지만 튜토리얼을 찾고 있다면 이곳이 완벽한 장소입니다. 클러스터링이 옵션이 아닌 경우 네임스페이스를 고려하고 키를 여러 인스턴스에 분산시키는 것을 고려하세요.
9. 코어는 많을수록 좋나요? !
물론 틀렸어요. Redis는 단일 스레드 프로세스이며 지속성이 활성화된 경우에도 최대 2개의 코어만 소비합니다. 단일 호스트에서 여러 인스턴스를 실행할 계획이 아니라면 개발 및 테스트 환경에서만 가능하기를 바랍니다. ——그렇지 않으면 Redis 인스턴스에 2개 이상의 코어가 필요하지 않습니다.
10. 고가용성
지금까지 Redis Sentinel은 철저한 테스트를 거쳤으며 많은 사용자가 이를 프로덕션 환경(ObjectRocket 포함)에 적용했습니다. 애플리케이션이 Redis에 크게 의존하는 경우 오프라인 상태가 되지 않도록 고가용성 솔루션을 마련해야 합니다.
자세한 내용은 java 기본 튜토리얼칼럼
을 참고해주세요.위 내용은 10가지 Redis 사용 팁의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

핫 AI 도구

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

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

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

Clothoff.io
AI 옷 제거제

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

인기 기사

뜨거운 도구

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

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

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

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

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

뜨거운 주제











1. [시작] 메뉴를 시작하여 [cmd]를 입력하고 [명령 프롬프트]를 마우스 오른쪽 버튼으로 클릭한 후 [관리자 권한으로 실행]을 선택합니다. 2. 다음 명령을 순서대로 입력합니다(주의 깊게 복사하여 붙여넣기): SCconfigwuauservstart=auto, Enter SCconfigbitsstart=auto, Enter 누르기 SCconfigcryptsvcstart=auto, Enter SCconfigtrustedinstallerstart=auto, Enter SCconfigwuauservtype=share, Enter netstopwuauserv , Enter netstopcryptS 누르기

PHP 함수 병목 현상은 성능 저하로 이어지며, 이는 병목 현상 기능을 찾아 성능 분석 도구를 사용하는 단계를 통해 해결할 수 있습니다. 재계산을 줄이기 위해 결과를 캐싱합니다. 작업을 병렬로 처리하여 실행 효율성을 높입니다. 문자열 연결을 최적화하고 대신 내장 함수를 사용하세요. 사용자 정의 함수 대신 내장 함수를 사용하십시오.

GolangAPI의 캐싱 전략은 성능을 향상시키고 서버 부하를 줄일 수 있습니다. 일반적으로 사용되는 전략은 LRU, LFU, FIFO 및 TTL입니다. 최적화 기술에는 적절한 캐시 스토리지 선택, 계층적 캐싱, 무효화 관리, 모니터링 및 조정이 포함됩니다. 실제 사례에서 LRU 캐시는 데이터베이스에서 사용자 정보를 얻기 위한 API를 최적화하는 데 사용됩니다. 그렇지 않으면 캐시를 데이터베이스에서 얻은 후 업데이트할 수 있습니다.

Erlang과 Go 사이에는 성능 차이가 있습니다. Erlang은 동시성이 뛰어나고 Go는 더 높은 처리량과 더 빠른 네트워크 성능을 제공합니다. Erlang은 높은 동시성을 요구하는 시스템에 적합한 반면, Go는 높은 처리량과 짧은 대기 시간을 요구하는 시스템에 적합합니다.

PHP 개발에서 캐싱 메커니즘은 자주 액세스하는 데이터를 메모리나 디스크에 임시 저장하여 데이터베이스 액세스 횟수를 줄여 성능을 향상시킵니다. 캐시 유형에는 주로 메모리, 파일 및 데이터베이스 캐시가 포함됩니다. 캐싱은 내장 함수나 캐시_get() 및 Memcache와 같은 타사 라이브러리를 사용하여 PHP에서 구현할 수 있습니다. 일반적인 실제 응용 프로그램에는 쿼리 성능을 최적화하기 위한 데이터베이스 쿼리 결과 캐싱과 렌더링 속도를 높이기 위한 페이지 출력 캐싱이 포함됩니다. 캐싱 메커니즘은 웹사이트 응답 속도를 효과적으로 향상시키고, 사용자 경험을 향상시키며, 서버 부하를 줄입니다.

Redis 캐시를 사용하면 PHP 배열 페이징 성능을 크게 최적화할 수 있습니다. 이는 다음 단계를 통해 달성할 수 있습니다. Redis 클라이언트를 설치합니다. Redis 서버에 연결합니다. 캐시 데이터를 생성하고 "page:{page_number}" 키를 사용하여 각 데이터 페이지를 Redis 해시에 저장합니다. 캐시에서 데이터를 가져오고 대규모 어레이에서 비용이 많이 드는 작업을 피하세요.

먼저 시스템 언어를 중국어 간체 표시로 설정하고 다시 시작해야 합니다. 물론 이전에 표시 언어를 중국어 간체로 변경했다면 이 단계를 건너뛰어도 됩니다. 다음으로 레지스트리 조작을 시작하여 regedit.exe를 실행하고 왼쪽 탐색바 또는 상단 주소 표시줄의 HKEY_LOCAL_MACHINESYSTEMCurrentControlSetControlNlsLanguage로 직접 이동한 후 InstallLanguage 키 값과 Default 키 값을 0804로 수정합니다(영어 en-로 변경하려는 경우). 먼저 시스템 표시 언어를 en-us로 설정하고 시스템을 다시 시작한 다음 모든 항목을 0409로 변경해야 합니다. 이 시점에서 시스템을 다시 시작해야 합니다.

네, Navicat은 사용자가 키를 관리하고, 값을 보고, 명령을 실행하고, 활동을 모니터링하고, 문제를 진단할 수 있는 Redis에 연결할 수 있습니다. Redis에 연결하려면 Navicat에서 "Redis" 연결 유형을 선택하고 서버 세부 정보를 입력하세요.
