데이터 베이스 MySQL 튜토리얼 Redis+Keepalived内存数据库集群配置

Redis+Keepalived内存数据库集群配置

Jun 07, 2016 pm 03:10 PM
레디스 클러스터

Redis是一个开源的使用ANSI C语言编写、支持网络、可基于内存亦可持久化的日志型、Key-Value数据库,并提供多种语言的API。

前言:Redis是一个开源的使用ANSI C语言编写、支持网络、可基于内存亦可持久化的日志型、Key-Value数据库,并提供多种语言的API。

Redis是一个key-value存储系统。和Memcached类似,它支持存储的value类型相对更多,包括string(字符串)、list(链表)、set(集合)、zset(sorted set --有序集合)和hash(哈希类型)。

Redis是一种高级key-value数据库。它跟memcached类似,不过数据可以持久化,而且支持的数据类型很丰富。有字符串,链表,集合和有序集合。支持在服务器端计算集合的并,交和补集(difference)等,还支持多种排序功能。所以Redis也可以被看成是一个数据结构服务 器。

Redis的所有数据都是保存在内存中,然后不定期的通过异步方式保存到磁盘上(这称为“半持久化模式”);也可以把每一次数据变化都写入到一个usr/localend only file(aof)里面(这称为“全持久化模式”)。

为了提升redis高可用性,我们除了备份redis dump数据之外,还需要创建redis主从架构,可以利用从将数据库持久化(数据持久化通俗讲就是把数据保存到磁盘上,保证不会因为断电等因素丢失数据。

redis需要经常将内存中的数据同步到磁盘来保证持久化。redis支持两种持久化方式,一种是 Snapshotting(快照)也是默认方式,另一种是Append-only file(缩写aof)的方式。)

什么是redis的主从复制呢?

Redis主从复制,当用户往Master端写入数据时,通过Redis Sync机制将数据文件发送至Slave,Slave也会执行相同的操作确保数据一致;且实现Redis的主从复制非常简单。同时slave上还可以开启二级slave,三级slave从库,跟MySQL的主从类似。

安装redis可以参考上一次课程哦,这里直接安装slave,只需要在slave redis.conf配置文件中加入如下语句即可:

slaveof 192.168.33.10 6379  # slaveofmaster的ip master的端口。

一、安装Keepalived:

tar zxf keepalived-1.2.1.tar.gz

cd keepalived-1.2.1&&./configure --with-kernel-dir=/usr/src/kernels/2.6.18* &&make&& make install

DIR=/usr/local/ ;cp $DIR/etc/rc.d/init.d/keepalived  /etc/rc.d/init.d/

cp $DIR/etc/sysconfig/keepalived /etc/sysconfig/ &&mkdir -p /etc/keepalived

cp $DIR/sbin/keepalived /usr/sbin/

二、配置Keepalived:

vi /etc/keepalived/keepalied.conf

! Configuration File for keepalived

global_defs {

  notification_email{

      wgkgood@139.com

  }

  notification_email_fromwgkgood@139.com

  smtp_server127.0.0.1

  smtp_connect_timeout30

  router_idLVS_DEVEL

}

# VIP1

vrrp_instance VI_1 {

    state BACKUP 

    interface eth0

  lvs_sync_daemon_inteface eth0

    virtual_router_id151

    priority 100

    advert_int 5

    nopreempt

    authentication {

        auth_typePASS

        auth_pass2222

    }

    virtual_ipaddress{

        192.168.33.100

    }

}

virtual_server 192.168.33.100 6379 {

    delay_loop 6   

    lb_algo wrr   

    lb_kind DR 

    persistence_timeout60   

    protocol TCP       

    real_server 192.168.33.10 6379 {

        weight 100       

        notify_down/data/sh/redis.sh

        TCP_CHECK {

        connect_timeout10

        nb_get_retry3

        delay_before_retry3

        connect_port6379

        }

    }

}

三、从Keepalived配置:

Redis从服务器配置keepalived.conf跟master一样,只需要把Realserver IP修改成:

real_server 192.168.33.11 ;优先级从100改成90即可。

vi /etc/keepalived/keepalied.conf

! Configuration File for keepalived

global_defs {

  notification_email{

      wgkgood@139.com

  }

  notification_email_fromwgkgood@139.com

  smtp_server127.0.0.1

  smtp_connect_timeout30

  router_idLVS_DEVEL

}

# VIP1

vrrp_instance VI_1 {

    state BACKUP 

    interface eth0

  lvs_sync_daemon_inteface eth0

    virtual_router_id151

    priority 90

    advert_int 5

    nopreempt

    authentication {

        auth_typePASS

        auth_pass2222

    }

    virtual_ipaddress{

        192.168.33.100

    }

}

virtual_server 192.168.33.100 6379 {

    delay_loop 6   

    lb_algo wrr   

    lb_kind DR 

    persistence_timeout60   

    protocol TCP       

    real_server 192.168.33.11 6379 {

        weight 100       

        notify_down/data/sh/redis.sh

        TCP_CHECK {

        connect_timeout10

        nb_get_retry3

        delay_before_retry3

        connect_port6379

        }

    }

}

四、创建切换脚本:

在master、slave数据库上创建/data/sh/redis.sh脚本,内容为:

/etc/init.d/keepalived stop

然后分别重启两台Redis数据库上keepalived服务即可。

最后测试停止master Mysql服务,,是否会自动切换到Backup上即可。

下面关于Redis的文章您也可能喜欢,不妨参考下:

Ubuntu 14.04下Redis安装及简单测试

Redis主从复制基本配置

Redis集群明细文档

Ubuntu 12.10下安装Redis(图文详解)+ Jedis连接Redis

Redis系列-安装部署维护篇

CentOS 6.3安装Redis

Redis安装部署学习笔记

Redis配置文件redis.conf 详解

Redis 的详细介绍:请点这里
Redis 的下载地址:请点这里

本文永久更新链接地址

본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.

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

인기 기사

R.E.P.O. 에너지 결정과 그들이하는 일 (노란색 크리스탈)
3 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 최고의 그래픽 설정
3 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 아무도들을 수없는 경우 오디오를 수정하는 방법
3 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25 : Myrise에서 모든 것을 잠금 해제하는 방법
4 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

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

SublimeText3 중국어 버전

SublimeText3 중국어 버전

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

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

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

ThinkPHP6을 사용하여 Redis 클러스터 구현 ThinkPHP6을 사용하여 Redis 클러스터 구현 Jun 20, 2023 am 08:36 AM

인터넷의 급속한 발전으로 인해 높은 동시성 문제가 점점 더 두드러지고 있습니다. 이러한 문제에 대한 대응으로 Redis의 등장은 메모리 읽기 및 쓰기를 통해 기존 관계형 데이터베이스의 과도한 읽기 및 쓰기 부담 문제를 해결하는 중요한 솔루션이 되었습니다. 그러나 단일 노드 Redis는 높은 동시성 조건에서 여전히 성능 병목 현상이 발생하므로 Redis 클러스터를 사용해야 합니다. 이 문서에서는 ThinkPHP6을 사용하여 Redis 클러스터를 구현하는 방법을 설명합니다. 1. Redis Cluster 소개 Redis Cluster는 Redis에서 제공하는 공식 클러스터이다.

Redis 및 Node.js 클러스터 솔루션: 고가용성을 달성하는 방법 Redis 및 Node.js 클러스터 솔루션: 고가용성을 달성하는 방법 Jul 29, 2023 pm 05:42 PM

Redis 및 Node.js용 클러스터 솔루션: 고가용성을 달성하는 방법 소개: 인터넷의 급속한 발전으로 인해 데이터 처리가 점점 더 커지고 복잡해졌습니다. 시스템의 고가용성과 확장성을 보장하려면 분산 클러스터 아키텍처를 사용하여 대량의 데이터를 저장하고 처리해야 하는 요구 사항을 처리해야 합니다. 고성능 인메모리 데이터베이스인 Redis는 백엔드 프로그래밍 언어인 Node.js와 결합되어 가용성이 높은 분산 클러스터 솔루션을 구축할 수 있습니다. 이 기사에서는 Redis와 Node.js를 사용하여 구현하는 방법을 소개합니다.

Redis를 통해 PHP 데이터 캐시의 클러스터 배포를 구현하는 방법은 무엇입니까? Redis를 통해 PHP 데이터 캐시의 클러스터 배포를 구현하는 방법은 무엇입니까? Aug 10, 2023 am 08:13 AM

Redis를 통해 PHP 데이터 캐시의 클러스터 배포를 구현하는 방법은 무엇입니까? 소개: PHP 애플리케이션이 높은 동시성과 대규모 트래픽에 직면할 때 종종 데이터베이스 성능 병목 현상이 발생합니다. 이때 캐싱 기술을 사용하면 시스템의 성능과 동시성을 크게 향상시킬 수 있습니다. 고성능 인메모리 키-값 데이터베이스인 Redis는 캐싱 솔루션 구현에 널리 사용됩니다. 이 기사에서는 Redis를 통해 PHP 데이터 캐시의 클러스터 배포를 구현하여 성능과 확장성을 더욱 향상시키는 방법을 소개합니다. 1. Redis 클러스터 Redis 개요

Redis의 Redis 클러스터 및 PHP 사용 방법 Redis의 Redis 클러스터 및 PHP 사용 방법 May 15, 2023 pm 03:22 PM

Redis는 강력한 인메모리 키-값 쌍 스토리지 데이터베이스입니다. 일반 RDBMS(관계형 데이터베이스 관리 시스템)보다 성능과 확장성이 뛰어납니다. Redis의 장점 중 하나는 분산 시스템의 핵심 기술로 활용될 수 있다는 점이다. 이번 글에서는 Redis Cluster의 개념과 PHP에서 Redis Cluster를 사용하는 방법을 살펴보겠습니다. Redis 클러스터란 무엇입니까? 간단히 말해서 Redis 클러스터는 여러 Redis 인스턴스의 집합입니다. Redis 클러스터를 사용하면

Go 언어로 데이터베이스 기능을 배우고 Redis 클러스터에서 읽기 및 쓰기 작업을 구현합니다. Go 언어로 데이터베이스 기능을 배우고 Redis 클러스터에서 읽기 및 쓰기 작업을 구현합니다. Jul 29, 2023 pm 12:21 PM

Go 언어의 데이터베이스 기능을 배우고 Redis 클러스터에서 읽기 및 쓰기 작업을 구현합니다. 소개: 데이터베이스는 오늘날 인터넷 애플리케이션에 없어서는 안 될 부분입니다. Go 언어는 간단하고 효율적인 프로그래밍 언어로서 우수한 데이터베이스 작업 기능도 갖추고 있습니다. 이 기사에서는 Go 언어에서 데이터베이스 기능을 사용하고 Redis 클러스터에서 읽기 및 쓰기 작업을 구현하는 방법을 소개합니다. 1. Go 언어의 데이터베이스 기능 Go 언어의 데이터베이스 작업은 주로 Database/SQL 패키지를 통해 구현됩니다. 이 패키지는 기본 데이터를 제공합니다

Redis 및 PHP 클러스터 솔루션: 고가용성과 확장성을 달성하는 방법 Redis 및 PHP 클러스터 솔루션: 고가용성과 확장성을 달성하는 방법 Jul 30, 2023 pm 08:51 PM

Redis 및 PHP 클러스터 솔루션: 고가용성과 확장성을 달성하는 방법 소개: Redis는 빠르고 확장 가능한 애플리케이션을 구축하는 데 자주 사용되는 오픈 소스 고성능 인메모리 데이터베이스입니다. 널리 사용되는 서버 측 스크립팅 언어인 PHP를 Redis와 함께 사용하면 고가용성 및 확장성 클러스터 솔루션을 구현할 수 있습니다. 이 문서에서는 Redis와 PHP를 사용하여 고가용성 및 확장 가능한 클러스터를 구축하는 방법을 소개하고 코드 예제를 통해 자세히 설명합니다. 1. Redis 클러스터 Re의 구축, 설치 및 구성

Redis 및 Julia 언어를 사용하여 고가용성 클러스터 기능을 구현하는 방법 Redis 및 Julia 언어를 사용하여 고가용성 클러스터 기능을 구현하는 방법 Sep 20, 2023 am 10:58 AM

Redis 및 Julia 언어를 사용하여 고가용성 클러스터 기능을 구현하는 방법 소개: 인터넷 비즈니스가 발전함에 따라 시스템 가용성에 대한 요구 사항이 점점 더 높아지고 있습니다. 장애 발생 시 시스템이 계속해서 서비스를 제공할 수 있도록 보장하기 위해 고가용성은 다양한 산업 분야의 핵심 요구 사항 중 하나가 되었습니다. 이 기사에서는 Redis 및 Julia 언어를 사용하여 고가용성 클러스터 기능을 구현하는 방법을 소개하고 구체적인 코드 예제를 제공합니다. 1. 고가용성 클러스터란 무엇입니까? 고가용성 클러스터는 여러 노드를 함께 구성하여 전체 시스템을 구성합니다.

Redis 클러스터 확장 계획 및 구현 세부 사항 Redis 클러스터 확장 계획 및 구현 세부 사항 Jun 21, 2023 am 10:58 AM

Redis는 고성능 오픈 소스 인 메모리 데이터 스토리지 서비스로, 빠른 읽기 및 쓰기 속도, 영구 스토리지, 다양한 데이터 구조 지원으로 인해 개발자들의 선호도가 높아지고 있습니다. 비즈니스가 계속 성장함에 따라 Redis의 스토리지 용량은 더 이상 수요를 충족할 수 없으며 확장이 필요합니다. 이 글에서는 Redis 클러스터 확장 계획과 구현 세부 사항을 소개합니다. Redis 클러스터의 개념 Redis 클러스터는 여러 Redis 인스턴스를 함께 연결하여 대규모 Redis 인스턴스 세트를 형성하는 것을 의미하며 이는 Redis를 향상시킬 수 있습니다.

See all articles