redis는 c 언어
로 작성된 오픈 소스 고가용성 소프트웨어입니다. code>비관계형 데이터베이스(단순 데이터베이스가 아닌 NoSQL) 유형의 키-값 데이터베이스입니다. c语言
编写的,开源的高可用的非关系型数据库
(NoSQL,不仅仅是数据库)型的键值对(key-value)数据库。
与传统的数据库不同的是redis的数据是存在内存
메모리
에 존재하므로 읽기 및 쓰기 성능이 일반적으로 높지 않고 초당 100,000회 작업에 도달할 수 있으므로 캐싱에 널리 사용됩니다. 웹 사이트 아키텍처에서 Tomcat과 세션을 공유하고, 데이터베이스 캐싱을 수행하는 등의 작업을 수행합니다. redis의 장점과 단점장점
다양한 데이터 구조, 문자열(문자열, 가장 일반적으로 사용됨), 해시(해시), 목록(목록), 집합(SET), 순서 집합(ZSET) 지원 )
두 가지 영구 데이터 형식인 AOF, RDB 및 이 둘의 혼합인 AOF와 RDB를 지원합니다.
데이터 유형 | 저장된 값 | 자주 사용하는 작업 명령 | 응용 시나리오 |
---|---|---|---|
string | string | SET(생성), GET(보기), DEL(삭제), MSET(일괄 생성), MGET(일괄 보기) | 캐시, 키-값 쌍의 만료 시간, 세션 저장 redis, 만료 후 삭제, 사용자 정보 캐시, Mysql 데이터 일부, 쇼핑몰 쿠폰 만료 시간 등 |
list | list | RPUSH(생성, 존재하는 경우 오른쪽에 추가), LPUSH(추가) 왼쪽, LRABGE+range(범위 값 보기), RPOP(오른쪽 마지막 값 삭제) a), LPOP(왼쪽 마지막 값 삭제) | 일반적으로 zset과 조합하여 사용되며 주로 순위에 사용되며, 인기/클릭 순위, 생방송 방 순위 등 |
hash | Hash | HMSET+ Object(오브젝트의 키값 생성, 대상 지정), HGET+ object(오브젝트의 매개변수 보기) | 일반적으로 키는 ID 또는 고유 식별자이고 값은 제품 정보, 개인 정보, 뉴스 등 해당 세부 정보입니다. |
SET | Unordered set | SADD(세트 생성), SMEMBERS(세트 보기), SREM(세트 값 삭제), SDIFF 세트 1 세트 2(차이 세트 찾기), SINTER 세트 1 세트 2(결합 찾기), SUNION 세트 1 세트 2(결합 찾기) | 공통 취미, 공통 친구 등 소셜 네트워크에 적용되는 교차점, 조합, 컬렉션 찾기 |
ZSET | Ordered set | SET | 을 사용하면 이를 목록과 결합하여 순위를 완성할 수 있습니다. |
1. 데이터 디렉토리 생성
mkdir -p /redis/soft mkdir -p /opt/redis_cluster/redis_6379/{conf,logs,pid}
conf,logs,pid 디렉토리를 초기화하고 자동 생성하는 대신 직접 생성하는 이유를 설명하세요
여러 파일을 열기 위함입니다. 하나의 호스트에서 최신 Redis 클러스터(최소 6개)를 구현하기 위한 Redis 프로세스(작성자 컴퓨터 구성으로 인해 임의로 작동할 수 없음)
2 Redis 설치 패키지를 다운로드합니다
cd /redis/soft wget http://download.redis.io/releases/redis-5.0.6.tar.gz
3. /
tar zxf redis-5.0.6.tar.gz -C /opt/redis_cluster/ ln -s /opt/redis_cluster/redis-5.0.6 /opt/redis_cluster/redis #做好软连接,方便自己管理
4. redis
cd /opt/redis_cluster/redis make && make install
5를 설치할 디렉터리를 변경하세요. 자신만의 구성 파일 /opt/redis_cluster/redis_6379/conf/6379.conf
/opt/redis_cluster/redis_6379/conf/6379.conf
添加一些重要的内容
添加: bind 127.0.0.1 192.168.10.1 port 6379 daemonize yes #开启daemon进程pidfile /opt/redis_cluster/redis_6379/pid/redis_6379.pid logfile /opt/redis_cluster/redis_6379/logs/redis_6379.log databases 16 dbfilename redis.rdb #RDB持久化文件dir /opt/redis_cluster/redis_6379 #RDB存放的位置
6.启动当前redis服务redis-server /opt/redis_cluster/redis_6379/conf/6379.conf
[root@redis-master ~]# netstat -anpt |grep 6379tcp 0 0 192.168.10.1:6379 0.0.0.0:* LISTEN 49206/redis-server tcp 0 0 127.0.0.1:6379 0.0.0.0:* LISTEN 49206/redis-server tcp 0 0 127.0.0.1:41400 127.0.0.1:6379 TIME_WAIT - tcp 0 0 192.168.10.1:6379 192.168.10.8:46220 ESTABLISHED 49206/redis-server [root@redis-master ~]#
修改配置文件,添加save项
vim /opt/redis_cluster/redis_6379/conf/6379.conf 添加: save 900 1 #在900秒(15分钟)之后,如果至少有1个key发生变化,则dump内存快照。save 300 10 #在300秒(5分钟)之后,如果至少有10个key发生变化,则dump内存快照。save 60 500 #在60秒(1分钟)之后,如果至少有500个key发生变化,则dump内存快照
同为修改配置文件
添加appendonly,启用持久化
vim /opt/redis_cluster/redis_6379/conf/6379.conf 添加: appendonly yes #启用AOF持久化appendfilename "redis.aof" #指定AOF文件名appendfsync everysec #每秒同步一次
redis-cli shutdownredis-server /opt/redis_cluster/redis_6379/conf/6379.conf
在redis数据库里面添加键值对
#!/bin/bashfor i in {1..500}do redis-cli set k_$i v_$idone
这时候关闭数据库,内存里的东西正常肯定会丢失,但是,现在肯定不会丢失的,而且还会有持久化的文件
[root@redis-master ~]# redis-cli shutdown[root@redis-master ~]# redis-server /opt/redis_cluster/redis_6379/conf/6379.conf [root@redis-master ~]# [root@redis-master ~]# redis-cli127.0.0.1:6379> keys k_500 1) "v_500"127.0.0.1:6379>
为什么要做redis主从复制?
为解决单点故障把数据复制到一个或多个副本副本服务器(从服务器),实现冗余,达到故障恢复和负载均衡的目的
1.为了简单,我们直接复制前边master
[root@redis-master ~]# scp -rp /opt/redis_cluster/ root@192.168.10.8:/opt
2.直接make install
安装redis,无须再编译,在master已经做过
修改配置文件
cd /opt/redis_cluster/redis vim /opt/redis_cluster/redis_6379/conf/6379.conf 修改: bind 127.0.0.1 192.168.10.8 slaveof 192.168.10.1 6379 #添加master的ip port保存退出
3.启动服务
redis-server /opt/redis_cluster/redis_6379/conf/6379.conf
注:
从服务器在同步过程中,只能复制主数据库的数据,不能手动添加修改数据;
如果从服务器非要修改数据,需要断开同步:[root@redis-slave ~]# redis-cli slaveof no one
提示OK即可
如果master宕机的话,从服务器可以先手动断开同步
,这时候,他就是一个独立的个体,其他的从服务器再指向自己
중요한 내용을 추가하세요
redis-server /opt/redis_cluster/redis_6379/conf/6379.conf
구성 파일을 수정하고 저장 항목을 추가합니다rrreee
Persistence AOF 구성동일한 수정 구성 파일추가 전용 추가, 지속성 활성화
rrreee🎜redis를 다시 시작하여 적용하고 지속성 확인🎜rrreee🎜redis 데이터베이스에 키-값 쌍 추가🎜rrreee🎜 메모리에 있던 것들은 당연히 없어지겠지만 이제는 손실되지 않으며 영구 파일이 있을 것입니다🎜rrreee🎜🎜🎜redis 마스터-슬레이브 복제🎜🎜왜 Redis 마스터-슬레이브 복제를 수행해야 합니까? 🎜단일 장애점을 해결하려면 데이터를 하나 이상의 복제 서버(슬레이브 서버)에 복사하여 중복성을 확보하고 오류 복구 및 로드 밸런싱 목적을 달성하세요🎜🎜다른 서버를 시작하고 redis를 설치하세요🎜🎜1. 단순함, 이전 마스터🎜🎜[root@redis-master ~]# scp -rp /opt/redis_cluster/ root@192.168.10.8:/opt
🎜🎜2를 직접 복사합니다. make install redis를 설치합니다. 다시 컴파일할 필요가 없습니다. 구성 파일이 master🎜🎜🎜rrreee🎜3에서 수정되었습니다. 서비스를 시작하세요🎜🎜redis-server /opt/redis_cluster/redis_6379/conf /6379.conf
code>🎜🎜메인 서버에 새 키 값을 생성하고 슬레이브 서버의 자동 동기화 테스트🎜🎜🎜🎜참고: 🎜동기화 프로세스 중에 슬레이브 서버는 기본 데이터베이스의 데이터만 복사할 수 있으며 데이터를 수동으로 추가하거나 수정할 수 없습니다. 🎜슬레이브 서버의 경우 데이터를 수정해야 하며 동기화 연결을 끊어야 합니다. 🎜[root@redis -slave ~]# redis-clislaveof no one
🎜🎜그냥 프롬프트 OK🎜🎜마스터가 다운되면 슬레이브 서버는 동기화를 수동으로 연결 해제
할 수 있습니다. 이때 그는 독립적인 개인이며 다른 슬레이브 서버는 자신을 가리켜
전환을 완료할 수 있습니다🎜🎜🎜🎜🎜🎜🎜 🎜이 기사는 https://blog.csdn.net/weixin_43815140/article/details /106128848🎜🎜에서 복제되었습니다. 더 많은 관련 지식을 보려면 🎜PHP 중국어 웹사이트🎜를 방문하세요! ! 🎜위 내용은 Redis 지속성 구성(그림 및 텍스트 소개)의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!