찾다
운영 및 유지보수리눅스 운영 및 유지 관리Linux 운영 및 유지 관리를 위해 알아야 할 Redis 경험


Redis는 현재 기술 커뮤니티에서 매우 인기가 있습니다. Redis는 Antirez의 소규모 개인 프로젝트에서 인메모리 데이터 스토리지의 업계 표준이 되기까지 먼 길을 걸어왔습니다. 결과적인 모범 사례 세트를 통해 대부분의 사람들은 Redis를 올바르게 사용할 수 있습니다.

아래에서는 Redis를 올바르게 사용한 10가지 경험을 살펴보겠습니다.

1. KEYS 사용 중지 *

좋습니다. 이 명령에 도전하여 이 글을 시작하는 것은 좋은 방법이 아닐 수도 있지만 실제로 가장 중요한 포인트일 수 있습니다. 우리는 redis 인스턴스의 통계를 살펴볼 때 핵심 정보가 명확하게 표시되도록 "KEYS *" 명령을 빠르게 입력할 때가 많습니다. 공평하게 말하면 프로그래밍 관점에서 우리는 다음과 같은 의사 코드를 작성하는 경향이 있습니다.

for key in'keys *':
doAllTheThings() 

하지만 키가 1,300만 개이면 실행 속도가 느려집니다. 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-Benchmark 结果作为参考,而不要一概而论

Redis 之父 Salvatore 就说过:“通过执行GET/SET命令来测试Redis就像在雨天检测法拉利的雨刷清洁镜子的效果”。很多时候人们跑到我这里,他们想知道为什么自己的Redis-Benchmark统计的结果低于最优结果 。但我们必须要把各种不同的真实情况考虑进来,例如:

  • 可能受到哪些客户端运行环境的限制?
  • 是同一个版本号吗?
  • 测试环境中的表现与应用将要运行的环境是否一致?

Redis-Benchmark的测试结果提供了一个保证你的 Redis-Server 不会运行在非正常状态下的基准点,但是你永远不要把它作为一个真实的“压力测试”。压力测试需要反应出应用的运行方式,并且需要一个尽可能的和生产相似的环境。

4、Hashes 是你的最佳选择

以一种优雅的方式引入 hashes 吧。hashes 将会带给你一种前所未有的体验。之前我曾看到过许多类似于下面这样的key结构:

foo:first_name

foo:last_name

foo:address

上面的例子中,foo 可能是一个用户的用户名,其中的每一项都是一个单独的 key。这就增加了 犯错的空间,和一些不必要的 key。使用 hash 代替吧,你会惊奇地发现竟然只需要一个 key :

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、设置 key 值的存活时间

无论什么时候,只要有可能就利用key超时的优势。一个很好的例子就是储存一些诸如临时认证key之类的东西。当你去查找一个授权key时——以OAUTH为例——通常会得到一个超时时间。这样在设置key的时候,设成同样的超时时间,Redis就会自动为你清除!而不再需要使用KEYS *来遍历所有的key了,怎么样很方便吧?

6. 적절한 재활용 전략을 선택하세요

이제 키 지우기 주제에 대해 이야기했으므로 재활용 전략에 대해 이야기해 보겠습니다. Redis 인스턴스 공간이 가득 차면 일부 키 회수를 시도합니다. 사용량에 따라 키에 시간 초과를 설정한 경우 휘발성-lru 전략을 사용하는 것이 좋습니다. 그러나 캐시와 유사한 것을 실행 중이고 키에 대한 시간 초과 메커니즘을 설정하지 않은 경우 allkeys-lru 재활용 메커니즘 사용을 고려할 수 있습니다. 내 제안은 먼저 여기서 가능한 것이 무엇인지 확인하는 것입니다.

7. 데이터가 중요하다면 Try/Except를 사용하세요

중요한 데이터를 Redis 인스턴스에 넣을 수 있는지 확인해야 한다면 try/except 블록에 넣는 것이 좋습니다. 거의 모든 Redis 클라이언트는 "보내고 잊어버리기" 전략을 채택하므로 키가 실제로 Redis 데이터베이스에 있는지 여부를 고려해야 하는 경우가 많습니다. Redis 명령에 try/expect를 넣는 것의 복잡성은 이 문서의 내용이 아닙니다. 그렇게 하면 중요한 데이터가 있어야 할 곳에 배치된다는 점만 알면 됩니다.

8. 인스턴스를 소진하지 마세요

가능하면 여러 Redis 인스턴스의 작업 부하를 분산하세요. 버전 3.0.0부터 Redis는 클러스터를 지원합니다. Redis 클러스터를 사용하면 키 범위를 기반으로 마스터/슬레이브 모드를 포함하는 일부 키를 분리할 수 있습니다. 클러스터링 뒤에 숨은 완전한 "마법"은 여기에서 찾을 수 있습니다. 하지만 튜토리얼을 찾고 있다면 이곳이 완벽한 장소입니다. 클러스터링이 옵션이 아닌 경우 네임스페이스를 고려하고 키를 여러 인스턴스에 분산시키는 것이 좋습니다. 데이터 배포 방법에 관해 redis.io 웹사이트에 훌륭한 리뷰가 있습니다.

9. 코어는 많을수록 좋나요? !

물론 틀렸어요. Redis는 단일 스레드 프로세스이며 지속성이 활성화된 경우에도 최대 2개의 코어만 소비합니다. 단일 호스트에서 여러 인스턴스를 실행할 계획이 아니라면 개발 및 테스트 환경에서만 가능하기를 바랍니다. ——그렇지 않으면 Redis 인스턴스에 2개 이상의 코어가 필요하지 않습니다.

10. 고가용성

지금까지 Redis Sentinel은 철저한 테스트를 거쳤으며 많은 사용자가 이를 프로덕션 환경(ObjectRocket 포함)에 적용했습니다. 애플리케이션이 Redis에 크게 의존하는 경우 오프라인 상태가 되지 않도록 고가용성 솔루션을 마련해야 합니다. 물론 이러한 사항을 직접 관리하고 싶지 않다면 ObjectRocket이 고가용성 플랫폼과 7×24시간 기술 지원을 제공하므로 고려해 볼 수 있습니다.

위 내용은 Linux 운영 및 유지 관리를 위해 알아야 할 Redis 경험의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명
이 기사는 Linux中文社区에서 복제됩니다. 침해가 있는 경우 admin@php.cn으로 문의하시기 바랍니다. 삭제
Linux : 복구 모드에 들어가는 방법 (및 유지 보수)Linux : 복구 모드에 들어가는 방법 (및 유지 보수)Apr 18, 2025 am 12:05 AM

Linux 복구 모드를 입력하는 단계는 다음과 같습니다. 1. 시스템을 다시 시작하고 특정 키를 눌러 Grub 메뉴를 입력하십시오. 2. (복구 계)로 옵션을 선택하십시오. 3. FSCK 또는 루트와 같은 복구 모드 메뉴에서 작업을 선택하십시오. 복구 모드를 사용하면 단일 사용자 모드에서 시스템을 시작하고 파일 시스템 검사 및 수리를 수행하고 구성 파일 편집 및 기타 작업을 수행하여 시스템 문제를 해결할 수 있습니다.

Linux의 필수 구성 요소 : 초보자를위한 설명Linux의 필수 구성 요소 : 초보자를위한 설명Apr 17, 2025 am 12:08 AM

Linux의 핵심 구성 요소에는 커널, 파일 시스템, 쉘 및 공통 도구가 포함됩니다. 1. 커널은 하드웨어 리소스를 관리하고 기본 서비스를 제공합니다. 2. 파일 시스템은 데이터를 구성하고 저장합니다. 3. Shell은 사용자가 시스템과 상호 작용할 수있는 인터페이스입니다. 4. 일반적인 도구는 일상적인 작업을 완료하는 데 도움이됩니다.

Linux : 기본 구조를 살펴 봅니다Linux : 기본 구조를 살펴 봅니다Apr 16, 2025 am 12:01 AM

Linux의 기본 구조에는 커널, 파일 시스템 및 쉘이 포함됩니다. 1) 커널 관리 하드웨어 리소스 및 UNAME-R을 사용하여 버전을보십시오. 2) Ext4 파일 시스템은 큰 파일과 로그를 지원하며 mkfs.ext4를 사용하여 생성됩니다. 3) Shell은 Bash와 같은 명령 줄 상호 작용을 제공하고 LS-L을 사용하는 파일을 나열합니다.

Linux 운영 : 시스템 관리 및 유지 보수Linux 운영 : 시스템 관리 및 유지 보수Apr 15, 2025 am 12:10 AM

Linux 시스템 관리 및 유지 보수의 주요 단계에는 다음이 포함됩니다. 1) 파일 시스템 구조 및 사용자 관리와 같은 기본 지식을 마스터합니다. 2) 시스템 모니터링 및 리소스 관리를 수행하고 Top, HTOP 및 기타 도구를 사용하십시오. 3) 시스템 로그를 사용하여 문제를 해결하고 JournalCTL 및 기타 도구를 사용하십시오. 4) 자동 스크립트 및 작업 스케줄링을 작성하고 CRON 도구를 사용하십시오. 5) 보안 관리 및 보호 구현, iptables를 통해 방화벽을 구성합니다. 6) 성능 최적화 및 모범 사례를 수행하고 커널 매개 변수를 조정하며 좋은 습관을 개발하십시오.

Linux의 유지 관리 모드 이해 : 필수 요소Linux의 유지 관리 모드 이해 : 필수 요소Apr 14, 2025 am 12:04 AM

시작시 init =/bin/bash 또는 단일 매개 변수를 추가하여 Linux 유지 관리 모드가 입력됩니다. 1. 유지 보수 모드를 입력하십시오 : 그루브 메뉴를 편집하고 시작 매개 변수를 추가하십시오. 2. 파일 시스템을 다시 마운트하여 읽고 쓰기 모드 : MOUNT-OREMOUNT, RW/. 3. 파일 시스템 수리 : FSCK/DEV/SDA1과 같은 FSCK 명령을 사용하십시오. 4. 데이터 손실을 피하기 위해 데이터를 백업하고주의해서 작동합니다.

Debian이 Hadoop 데이터 처리 속도를 향상시키는 방법Debian이 Hadoop 데이터 처리 속도를 향상시키는 방법Apr 13, 2025 am 11:54 AM

이 기사에서는 데비안 시스템에서 Hadoop 데이터 처리 효율성을 향상시키는 방법에 대해 설명합니다. 최적화 전략에는 하드웨어 업그레이드, 운영 체제 매개 변수 조정, Hadoop 구성 수정 및 효율적인 알고리즘 및 도구 사용이 포함됩니다. 1. 하드웨어 리소스 강화는 모든 노드에 일관된 하드웨어 구성, 특히 CPU, 메모리 및 네트워크 장비 성능에주의를 기울일 수 있도록합니다. 전반적인 처리 속도를 향상시키기 위해서는 고성능 하드웨어 구성 요소를 선택하는 것이 필수적입니다. 2. 운영 체제 조정 파일 설명 자 및 네트워크 연결 : /etc/security/limits.conf 파일을 수정하여 파일 설명자의 상한을 늘리고 동시에 시스템에 의해 열 수 있습니다. JVM 매개 변수 조정 : Hadoop-env.sh 파일에서 조정

데비안 syslog를 배우는 방법데비안 syslog를 배우는 방법Apr 13, 2025 am 11:51 AM

이 안내서는 데비안 시스템에서 syslog를 사용하는 방법을 배우도록 안내합니다. Syslog는 로깅 시스템 및 응용 프로그램 로그 메시지를위한 Linux 시스템의 핵심 서비스입니다. 관리자가 시스템 활동을 모니터링하고 분석하여 문제를 신속하게 식별하고 해결하는 데 도움이됩니다. 1. syslog에 대한 기본 지식 syslog의 핵심 기능에는 다음이 포함됩니다. 로그 메시지 중앙 수집 및 관리; 다중 로그 출력 형식 및 대상 위치 (예 : 파일 또는 네트워크) 지원; 실시간 로그보기 및 필터링 기능 제공. 2. Syslog 설치 및 구성 (RSYSLOG 사용) Debian 시스템은 기본적으로 RSYSLOG를 사용합니다. 다음 명령으로 설치할 수 있습니다 : sudoaptupdatesud

데비안에서 Hadoop 버전을 선택하는 방법데비안에서 Hadoop 버전을 선택하는 방법Apr 13, 2025 am 11:48 AM

데비안 시스템에 적합한 Hadoop 버전을 선택할 때는 다음과 같은 주요 요소를 고려해야합니다. 1. 안정성 및 장기 지원 : 안정성과 보안을 추구하는 사용자의 경우 Debian11 (Bullseye)과 같은 데비안 안정 버전을 선택하는 것이 좋습니다. 이 버전은 완전히 테스트되었으며 최대 5 년의 지원주기가있어 시스템의 안정적인 작동을 보장 할 수 있습니다. 2. 패키지 업데이트 속도 : 최신 Hadoop 기능 및 기능을 사용해야하는 경우 Debian의 불안정한 버전 (SID)을 고려할 수 있습니다. 그러나 불안정한 버전에는 호환성 문제와 안정성 위험이있을 수 있습니다. 3. 커뮤니티 지원 및 자원 : 데비안은 풍부한 문서를 제공하고

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를 무료로 생성하십시오.

뜨거운 도구

VSCode Windows 64비트 다운로드

VSCode Windows 64비트 다운로드

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

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

MinGW - Windows용 미니멀리스트 GNU

MinGW - Windows용 미니멀리스트 GNU

이 프로젝트는 osdn.net/projects/mingw로 마이그레이션되는 중입니다. 계속해서 그곳에서 우리를 팔로우할 수 있습니다. MinGW: GCC(GNU Compiler Collection)의 기본 Windows 포트로, 기본 Windows 애플리케이션을 구축하기 위한 무료 배포 가능 가져오기 라이브러리 및 헤더 파일로 C99 기능을 지원하는 MSVC 런타임에 대한 확장이 포함되어 있습니다. 모든 MinGW 소프트웨어는 64비트 Windows 플랫폼에서 실행될 수 있습니다.

WebStorm Mac 버전

WebStorm Mac 버전

유용한 JavaScript 개발 도구

SublimeText3 Linux 새 버전

SublimeText3 Linux 새 버전

SublimeText3 Linux 최신 버전