Redis는 고성능, 경량이라는 뛰어난 기능으로 인해 인터넷 기업의 표준 캐시가 되었습니다. 주로 Redis를 많이 사용하는 시나리오(예: 급매수 시나리오)에서 일부 사용자 정의 명령을 추가하고 싶을 때가 있습니다. 원자성이 제대로 보장되지 않으면 여러 Redis 명령의 트랜잭션 특성으로 인해 데이터 불일치가 발생하기 쉬운지 확인해야 합니다.
공식적인 거래 계획이 제공되지만, 다음 단계로 진행하기 전에 특정 명령의 반환 값을 기반으로 판단해야 하는 경우 거래 계획에서는 이에 대처할 수 없습니다.
오늘은 실제 사례를 사용하여 Redis 명령을 추가하는 방법을 설명하겠습니다. 이 명령은 주로 스와이프 방지 시나리오에 사용됩니다.
특정 IP 또는 특정 사용자를 일정 기간 동안 차단해야 하는 경우가 많습니다. 이 명령을 사용하지 않는 경우 해결 방법은 다음과 같습니다.
먼저 증가한 다음 1인지 확인합니다. 1인 경우 만료 시간을 설정합니다. 높은 동시성 중에 증가 요청을 시작한 첫 번째 클라이언트가 중단되면 키가 만료되지 않는 것을 볼 수 있습니다.
오늘 작성하는 명령은 이 트랜잭션을 보장하는 데 사용됩니다. 서버는 키 값이 1일 때 만료 시간이 설정되도록 보장합니다.
명령 사용법은 다음과 같습니다.
incexpire key expireTime maxNum
key: 처리할 키
expireTime: 만료 시간(초) 10을 쓰면 키가 10초 후에 만료된다는 의미입니다. 10으로 설정되면 반환되는 최대값은 11입니다. 11을 반환하면 초과되었음을 의미합니다.
2.
1 명령을 작성합니다. 이 글에서 사용된 Redis 버전은
코드를 다운로드하고 3.2.11 브랜치로 잘라내세요
git clone https://github.com/antirez/redis
2. 명령을 추가하는 코드를 작성하세요
1) redisCommandTable 구조에 새로운 명령을 추가하세요. src/server.c
struct redisCommand redisCommandTable[] = {
redisCommandTable은 배열이며 각 항목은 redis 명령을 나타냅니다. 첫 번째는 명령의 이름, 두 번째는 실제로 처리되는 함수, 세 번째는 매개변수의 개수입니다. 다른 것들은 자세히 논의하지 않을 것입니다.
2) src/server.h에 함수 선언 추가:
void incrExpireCommand(client *c);
3) 그런 다음 새 파일을 ljh.c로 추가하고(이름을 직접 지정) 다음 코드를 추가합니다.
#include "server.h"
4) src/에 새 파일 추가 Makefile ljh.o
REDIS_SERVER_OBJ=adlist.o quicklist.o ae.o anet.o dict.o server.o sds.o zmalloc.o lzf_c.o lzf_d.o pqsort.o zipmap.o sha1.o ziplist.o release.o networking
파일의 실행 효과는 다음과 같습니다
key1이 11로 증가한 후 증가가 멈추고 10초 후에 다시 1이 되는 것을 볼 수 있습니다.마지막으로 우리 시나리오에 Redis 명령을 추가해야 하는지 스스로에게 물어봐야 합니다. 필요한 경우 각 계층 간의 책임을 파악하고 Redis가 일반적으로 미들웨어 계층에서 비즈니스를 처리하지 못하도록 해야 합니다. 말하자면, 보다 일반적인 기능을 처리할 때 하위 계층은 더 안정적이어야 하며 변경이 덜 필요한 것이 일반적인 상황입니다.
더 많은 관련 지식을 알고 싶다면
redis 입문 튜토리얼칼럼
을 주목해주세요.위 내용은 redis 명령을 추가하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!