PHP로 Redis 데이터베이스를 작동하는 일반적인 방법
Redis는 ANSI C 언어로 작성된 오픈소스 로그형 Key-Value 데이터베이스로, 네트워크를 지원하고, 메모리 기반 및 영속성이 가능하며, 다국어로 API를 제공합니다.
Redis는 Stirng(문자열), List(목록), Hash(사전), Set(집합), Sorted Set(주문된 집합)과 같은 데이터 유형을 지원합니다.
PHP를 Redis에서 사용할 수 있게 하려면 다음을 수행해야 합니다. 먼저 redis 확장을 설치하세요.
1. redis 설치
git 다운로드 주소 https://github.com/MSOpenTech/redis/releases
2.redis
windows 실행 테스트 Windows 키 + R 키), [cmd] 명령을 입력하여 DOC 운영 체제 창으로 들어갑니다.
redis 설치 디렉터리를 입력하고
2.1 명령을 사용하여 redis 데몬을 엽니다(redis 설치 디렉터리 입력)
redis-server.exe redis-windows-conf
2.2 Redis 클라이언트에 진입합니다(redis 설치 디렉터리 입력)
redis-cli.exe
3. php
다운로드 주소https://pecl.php.net/package/redis
의 Redis 확장을 설치합니다.phpinfo() 정보 redis 확장 압축 패키지를 기반으로 적절한 것을 선택하세요
4. redis 확장 패키지의 php_redis.dll 및 php_redis.pdb 파일을 ext 폴더
5에 넣습니다. php.ini 파일
extension=php_redis.dll
6. redis 확장 활성화
phpinfo() 정보 보기, redis
7.php를 검색하여 redis 데이터베이스 연결 및 테스트(redis 서비스 활성화를 기억하세요)인지 확인하세요.
새 test.php 만들기
<?php $redis = new Redis(); $redis->connect('127.0.0.1',6379); $redis->set('name','klc'); echo $redis->get('name'); ?>
데이터 유형에 대한 작업
Strng(String):
<?php // 设置一个字符串的值 $redis->set('cat', 111); //获取一个字符串的值 echo $redis->get('cat'); // 111 // 重复set $redis->set('cat', 222); echo $redis->get('cat'); // 222
List(List):
//列表 //存储数据到列表中 $redis->lpush('list', 'html'); $redis->lpush('list', 'css'); $redis->lpush('list', 'php'); //获取列表中所有的值 $list = $redis->lrange('list', 0, -1); print_r($list);echo '<br>'; //从右侧加入一个 $redis->rpush('list', 'mysql'); $list = $redis->lrange('list', 0, -1); print_r($list);echo '<br>'; //从左侧弹出一个 $redis->lpop('list'); $list = $redis->lrange('list', 0, -1); print_r($list);echo '<br>'; //从右侧弹出一个 $redis->rpop('list'); $list = $redis->lrange('list', 0, -1); print_r($list);echo '<br>'; // 结果 // Array ( [0] => php [1] => css [2] => html ) // Array ( [0] => php [1] => css [2] => html [3] => mysql ) // Array ( [0] => css [1] => html [2] => mysql ) // Array ( [0] => css [1] => html ) <?php //实例化redis $redis = new Redis(); //连接 $redis->connect('127.0.0.1', 6379); //列表 //存储数据到列表中 $redis->lpush('list', 'html'); $redis->lpush('list', 'css'); $redis->lpush('list', 'php'); $redis->lpush('list', 'mysql'); $redis->lpush('list', 'javascript'); $redis->lpush('list', 'ajax'); //获取列表中所有的值 $list = $redis->lrange('list', 0, -1); print_r($list);echo '<br>'; //获取列表的长度 $length = $redis->lsize('list'); echo $length;echo '<br>'; //返回列表key中index位置的值 echo $redis->lget('list', 2);echo '<br>'; echo $redis->lindex('list', 2);echo '<br>'; //设置列表中index位置的值 echo $redis->lset('list', 2, 'linux');echo '<br>'; $list = $redis->lrange('list', 0, -1); print_r($list);echo '<br>'; //返回key中从start到end位置间的元素 $list = $redis->lrange('list', 0, 2); print_r($list);echo '<br>'; $list = $redis->lgetrange('list', 0, 2); print_r($list);echo '<br>'; //截取链表中start到end的元素 //截取列表后列表发生变化,列表保留截取的元素,其余的删除 $list = $redis->ltrim('list', 0, 1); print_r($list);echo '<br>'; $list = $redis->lrange('list', 0, -1); print_r($list);echo '<br>'; // 结果 // Array ( [0] => ajax [1] => javascript [2] => mysql [3] => php [4] => css [5] => html ) // 6 // mysql // mysql // 1 // Array ( [0] => ajax [1] => javascript [2] => linux [3] => php [4] => css [5] => html ) // Array ( [0] => ajax [1] => javascript [2] => linux ) // Array ( [0] => ajax [1] => javascript [2] => linux ) // 1 // Array ( [0] => ajax [1] => javascript ) <?php //实例化redis $redis = new Redis(); //连接 $redis->connect('127.0.0.1', 6379); //列表 //存储数据到列表中 $redis->lpush('list', 'html'); $redis->lpush('list', 'html'); $redis->lpush('list', 'html'); $redis->lpush('list', 'css'); $redis->lpush('list', 'php'); $redis->lpush('list', 'mysql'); $redis->lpush('list', 'javascript'); $redis->lpush('list', 'html'); $redis->lpush('list', 'html'); $redis->lpush('list', 'html'); $redis->lpush('list', 'ajax'); //获取列表中所有的值 $list = $redis->lrange('list', 0, -1); print_r($list);echo '<br>'; //删除列表中count个值为value的元素 //从左向右删 $redis->lrem('list', 'html', 2); $list = $redis->lrange('list', 0, -1); print_r($list);echo '<br>'; //从右向左删 $redis->lrem('list', 'html', -2); $list = $redis->lrange('list', 0, -1); print_r($list);echo '<br>'; //删除所有 $redis->lrem('list', 'html', 0); $list = $redis->lrange('list', 0, -1); print_r($list);echo '<br>'; // 结果 // Array ( [0] => ajax [1] => html [2] => html [3] => html [4] => javascript [5] => mysql [6] => php [7] => css [8] => html [9] => html [10] => html ) // Array ( [0] => ajax [1] => html [2] => javascript [3] => mysql [4] => php [5] => css [6] => html [7] => html [8] => html ) // Array ( [0] => ajax [1] => html [2] => javascript [3] => mysql [4] => php [5] => css [6] => html ) // Array ( [0] => ajax [1] => javascript [2] => mysql [3] => php [4] => css )
Hash(Dictionary):
<?php //实例化redis $redis = new Redis(); //连接 $redis->connect('127.0.0.1', 6379); //字典 //给hash表中某个key设置value //如果没有则设置成功,返回1,如果存在会替换原有的值,返回0,失败返回0 echo $redis->hset('hash', 'cat', 'cat');echo '<br>'; echo $redis->hset('hash', 'cat', 'cat');echo '<br>'; echo $redis->hset('hash', 'cat', 'cat1');echo '<br>'; echo $redis->hset('hash', 'dog', 'dog');echo '<br>'; echo $redis->hset('hash', 'bird', 'bird');echo '<br>'; echo $redis->hset('hash', 'monkey', 'monkey');echo '<br>'; //获取hash中某个key的值 echo $redis->hget('hash', 'cat');echo '<br>'; //获取hash中所有的keys $arr = $redis->hkeys('hash'); print_r($arr);echo '<br>'; //获取hash中所有的值 顺序是随机的 $arr = $redis->hvals('hash'); print_r($arr);echo '<br>'; //获取一个hash中所有的key和value 顺序是随机的 $arr = $redis->hgetall('hash'); print_r($arr);echo '<br>'; //获取hash中key的数量 echo $redis->hlen('hash');echo '<br>'; //删除hash中一个key 如果表不存在或key不存在则返回false echo $redis->hdel('hash', 'dog');echo '<br>'; var_dump($redis->hdel('hash', 'rabbit'));echo '<br>'; // 结果 // 1 // 0 // 0 // 1 // 1 // 1 // cat1 // Array ( [0] => cat [1] => dog [2] => bird [3] => monkey ) // Array ( [0] => cat1 [1] => dog [2] => bird [3] => monkey ) // Array ( [cat] => cat1 [dog] => dog [bird] => bird [monkey] => monkey ) // 4 // 1 // int(0) <?php //实例化redis $redis = new Redis(); //连接 $redis->connect('127.0.0.1', 6379); //字典 //批量设置多个key的值 $arr = [1=>1, 2=>2, 3=>3, 4=>4, 5=>5]; $redis->hmset('hash', $arr); print_r($redis->hgetall('hash'));echo '<br>'; // 批量获得额多个key的值 $arr = [1, 2, 3, 5]; $hash = $redis->hmget('hash', $arr); print_r($hash);echo '<br>'; //检测hash中某个key知否存在 echo $redis->hexists('hash', '1');echo '<br>'; var_dump($redis->hexists('hash', 'cat'));echo '<br>'; print_r($redis->hgetall('hash'));echo '<br>'; //给hash表中key增加一个整数值 $redis->hincrby('hash', '1', 1); print_r($redis->hgetall('hash'));echo '<br>'; //给hash中的某个key增加一个浮点值 $redis->hincrbyfloat('hash', 2, 1.3); print_r($redis->hgetall('hash'));echo '<br>'; //结果 // Array ( [1] => 1 [2] => 2 [3] => 3 [4] => 4 [5] => 5 ) // Array ( [1] => 1 [2] => 2 [3] => 3 [5] => 5 ) // 1 // bool(false) // Array ( [1] => 1 [2] => 2 [3] => 3 [4] => 4 [5] => 5 ) // Array ( [1] => 2 [2] => 2 [3] => 3 [4] => 4 [5] => 5 ) // Array ( [1] => 2 [2] => 3.3 [3] => 3 [4] => 4 [5] => 5 )
Set(Set):
<?php //实例化redis $redis = new Redis(); //连接 $redis->connect('127.0.0.1', 6379); //集合 // 添加一个元素 echo $redis->sadd('set', 'cat');echo '<br>'; echo $redis->sadd('set', 'cat');echo '<br>'; echo $redis->sadd('set', 'dog');echo '<br>'; echo $redis->sadd('set', 'rabbit');echo '<br>'; echo $redis->sadd('set', 'bear');echo '<br>'; echo $redis->sadd('set', 'horse');echo '<br>'; // 查看集合中所有的元素 $set = $redis->smembers('set'); print_r($set);echo '<br>'; //删除集合中的value echo $redis->srem('set', 'cat');echo '<br>'; var_dump($redis->srem('set', 'bird'));echo '<br>'; $set = $redis->smembers('set'); print_r($set);echo '<br>'; //判断元素是否是set的成员 var_dump($redis->sismember('set', 'dog'));echo '<br>'; var_dump($redis->sismember('set', 'bird'));echo '<br>'; //查看集合中成员的数量 echo $redis->scard('set');echo '<br>'; //移除并返回集合中的一个随机元素(返回被移除的元素) echo $redis->spop('set');echo '<br>'; print_r($redis->smembers('set'));echo '<br>'; // 结果 // 1 // 0 // 1 // 1 // 1 // 1 // Array ( [0] => rabbit [1] => cat [2] => bear [3] => dog [4] => horse ) // 1 // int(0) // Array ( [0] => dog [1] => rabbit [2] => horse [3] => bear ) // bool(true) // bool(false) // 4 // bear // Array ( [0] => dog [1] => rabbit [2] => horse )
<?php //实例化redis $redis = new Redis(); //连接 $redis->connect('127.0.0.1', 6379); //集合 $redis->sadd('set', 'horse'); $redis->sadd('set', 'cat'); $redis->sadd('set', 'dog'); $redis->sadd('set', 'bird'); $redis->sadd('set2', 'fish'); $redis->sadd('set2', 'dog'); $redis->sadd('set2', 'bird'); print_r($redis->smembers('set'));echo '<br>'; print_r($redis->smembers('set2'));echo '<br>'; //返回集合的交集 print_r($redis->sinter('set', 'set2'));echo '<br>'; //执行交集操作 并结果放到一个集合中 $redis->sinterstore('output', 'set', 'set2'); print_r($redis->smembers('output'));echo '<br>'; //返回集合的并集 print_r($redis->sunion('set', 'set2'));echo '<br>'; //执行并集操作 并结果放到一个集合中 $redis->sunionstore('output', 'set', 'set2'); print_r($redis->smembers('output'));echo '<br>'; //返回集合的差集 print_r($redis->sdiff('set', 'set2'));echo '<br>'; //执行差集操作 并结果放到一个集合中 $redis->sdiffstore('output', 'set', 'set2'); print_r($redis->smembers('output'));echo '<br>'; // 结果 // Array ( [0] => cat [1] => dog [2] => bird [3] => horse ) // Array ( [0] => bird [1] => dog [2] => fish ) // Array ( [0] => bird [1] => dog ) // Array ( [0] => dog [1] => bird ) // Array ( [0] => cat [1] => dog [2] => bird [3] => horse [4] => fish ) // Array ( [0] => cat [1] => dog [2] => bird [3] => horse [4] => fish ) // Array ( [0] => horse [1] => cat ) // Array ( [0] => horse [1] => cat )
Sorted Set:
<?php //实例化redis $redis = new Redis(); //连接 $redis->connect('127.0.0.1', 6379); //有序集合 //添加元素 echo $redis->zadd('set', 1, 'cat');echo '<br>'; echo $redis->zadd('set', 2, 'dog');echo '<br>'; echo $redis->zadd('set', 3, 'fish');echo '<br>'; echo $redis->zadd('set', 4, 'dog');echo '<br>'; echo $redis->zadd('set', 4, 'bird');echo '<br>'; //返回集合中的所有元素 print_r($redis->zrange('set', 0, -1));echo '<br>'; print_r($redis->zrange('set', 0, -1, true));echo '<br>'; //返回元素的score值 echo $redis->zscore('set', 'dog');echo '<br>'; //返回存储的个数 echo $redis->zcard('set');echo '<br>'; //删除指定成员 $redis->zrem('set', 'cat'); print_r($redis->zrange('set', 0, -1));echo '<br>'; //返回集合中介于min和max之间的值的个数 print_r($redis->zcount('set', 3, 5));echo '<br>'; //返回有序集合中score介于min和max之间的值 print_r($redis->zrangebyscore('set', 3, 5));echo '<br>'; print_r($redis->zrangebyscore('set', 3, 5, ['withscores'=>true]));echo '<br>'; //返回集合中指定区间内所有的值 print_r($redis->zrevrange('set', 1, 2));echo '<br>'; print_r($redis->zrevrange('set', 1, 2, true));echo '<br>'; //有序集合中指定值的socre增加 echo $redis->zscore('set', 'dog');echo '<br>'; $redis->zincrby('set', 2, 'dog'); echo $redis->zscore('set', 'dog');echo '<br>'; //移除score值介于min和max之间的元素 print_r($redis->zrange('set', 0, -1, true));echo '<br>'; print_r($redis->zremrangebyscore('set', 3, 4));echo '<br>'; print_r($redis->zrange('set', 0, -1, true));echo '<br>'; //结果 // 1 // 0 // 0 // 0 // 0 // Array ( [0] => cat [1] => fish [2] => bird [3] => dog ) // Array ( [cat] => 1 [fish] => 3 [bird] => 4 [dog] => 4 ) // 4 // 4 // Array ( [0] => fish [1] => bird [2] => dog ) // 3 // Array ( [0] => fish [1] => bird [2] => dog ) // Array ( [fish] => 3 [bird] => 4 [dog] => 4 ) // Array ( [0] => bird [1] => fish ) // Array ( [bird] => 4 [fish] => 3 ) // 4 // 6 // Array ( [fish] => 3 [bird] => 4 [dog] => 6 ) // 2 // Array ( [dog] => 6 )
추천 학습: "PHP Tutorial"
위 내용은 PHP로 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)

뜨거운 주제











PHP의 미래는 새로운 기술 트렌드에 적응하고 혁신적인 기능을 도입함으로써 달성 될 것입니다. 1) 클라우드 컴퓨팅, 컨테이너화 및 마이크로 서비스 아키텍처에 적응, Docker 및 Kubernetes 지원; 2) 성능 및 데이터 처리 효율을 향상시키기 위해 JIT 컴파일러 및 열거 유형을 도입합니다. 3) 지속적으로 성능을 최적화하고 모범 사례를 홍보합니다.

PHP와 Python은 각각 고유 한 장점이 있으며 선택은 프로젝트 요구 사항을 기반으로해야합니다. 1.PHP는 간단한 구문과 높은 실행 효율로 웹 개발에 적합합니다. 2. Python은 간결한 구문 및 풍부한 라이브러리를 갖춘 데이터 과학 및 기계 학습에 적합합니다.

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

PHP는 죽지 않고 끊임없이 적응하고 진화합니다. 1) PHP는 1994 년부터 새로운 기술 트렌드에 적응하기 위해 여러 버전 반복을 겪었습니다. 2) 현재 전자 상거래, 컨텐츠 관리 시스템 및 기타 분야에서 널리 사용됩니다. 3) PHP8은 성능과 현대화를 개선하기 위해 JIT 컴파일러 및 기타 기능을 소개합니다. 4) Opcache를 사용하고 PSR-12 표준을 따라 성능 및 코드 품질을 최적화하십시오.

Redis 지시 사항을 사용하려면 다음 단계가 필요합니다. Redis 클라이언트를 엽니 다. 명령 (동사 키 값)을 입력하십시오. 필요한 매개 변수를 제공합니다 (명령어마다 다름). 명령을 실행하려면 Enter를 누르십시오. Redis는 작업 결과를 나타내는 응답을 반환합니다 (일반적으로 OK 또는 -err).

Redis 서버를 시작하는 단계에는 다음이 포함됩니다. 운영 체제에 따라 Redis 설치. Redis-Server (Linux/MacOS) 또는 Redis-Server.exe (Windows)를 통해 Redis 서비스를 시작하십시오. Redis-Cli Ping (Linux/MacOS) 또는 Redis-Cli.exe Ping (Windows) 명령을 사용하여 서비스 상태를 확인하십시오. Redis-Cli, Python 또는 Node.js와 같은 Redis 클라이언트를 사용하여 서버에 액세스하십시오.

Redis 소스 코드를 이해하는 가장 좋은 방법은 단계별로 이동하는 것입니다. Redis의 기본 사항에 익숙해집니다. 특정 모듈을 선택하거나 시작점으로 기능합니다. 모듈 또는 함수의 진입 점으로 시작하여 코드를 한 줄씩 봅니다. 함수 호출 체인을 통해 코드를 봅니다. Redis가 사용하는 기본 데이터 구조에 익숙해 지십시오. Redis가 사용하는 알고리즘을 식별하십시오.

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