Redis+Keepalived内存数据库集群配置
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 的下载地址:请点这里
本文永久更新链接地址:

ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

AI Hentai Generator
AIヘンタイを無料で生成します。

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

SublimeText3 中国語版
中国語版、とても使いやすい

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

ドリームウィーバー CS6
ビジュアル Web 開発ツール

SublimeText3 Mac版
神レベルのコード編集ソフト(SublimeText3)

ホットトピック









インターネットの急速な発展に伴い、高い同時実行性の問題がますます顕著になってきました。この問題に対応するために、Redis の登場が重要な解決策となっており、従来のリレーショナル データベースにおけるメモリの読み書きによる過剰な読み書きの負荷の問題を解決します。ただし、単一ノード Redis は、同時実行性が高い状況では依然としてパフォーマンスのボトルネックがあるため、Redis クラスターを使用する必要があります。この記事では、ThinkPHP6 を使用して Redis クラスターを実装する方法について説明します。 1. Redis Cluster の概要 Redis Cluster は、Redis が提供する公式クラスターです。

Redis および Node.js のクラスター ソリューション: 高可用性を実現する方法 はじめに: インターネットの急速な発展に伴い、データ処理はますます大規模かつ複雑になってきました。システムの高可用性とスケーラビリティを確保するには、分散クラスター アーキテクチャを使用して、大量のデータの保存と処理のニーズに対処する必要があります。高性能のインメモリ データベースとしての Redis を、バックエンド プログラミング言語としての Node.js と組み合わせることで、可用性の高い分散クラスター ソリューションを構築できます。この記事ではRedisとNode.jsを使って実装する方法を紹介します。

Redis を介して PHP データ キャッシュのクラスター デプロイメントを実装するにはどうすればよいですか?はじめに: PHP アプリケーションが高い同時実行性と大規模なトラフィックに直面すると、データベースのパフォーマンスのボトルネックが発生することがよくありますが、このとき、キャッシュ テクノロジを使用すると、システムのパフォーマンスと同時実行性を大幅に向上させることができます。 Redis は、高性能のメモリ内キー/値データベースとして、キャッシュ ソリューションの実装に広く使用されています。この記事では、パフォーマンスとスケーラビリティをさらに向上させるために、Redis を介して PHP データ キャッシュのクラスター デプロイメントを実装する方法を紹介します。 1. Redis Cluster Redis の概要

Redis は、強力なメモリ内キーと値のペアのストレージ データベースです。通常の RDBMS (リレーショナル データベース管理システム) よりも高いパフォーマンスと優れた拡張性を備えています。 Redis の利点の 1 つは、分散システムのコア テクノロジとして使用できることです。この記事では、Redis Cluster の概念と、PHP で Redis Cluster を使用する方法について説明します。 Redis クラスターとは何ですか?簡単に言えば、Redis クラスターは複数の Redis インスタンスの集合体です。 Redis クラスターでできること

Go 言語でデータベース機能を学習し、Redis クラスターで読み取りおよび書き込み操作を実装します。 はじめに: データベースは今日のインターネット アプリケーションに不可欠な部分であり、Go 言語はシンプルで効率的なプログラミング言語として、優れたデータベース操作機能も備えています。この記事では、Go 言語でデータベース関数を使用し、Redis クラスターで読み取りおよび書き込み操作を実装する方法を紹介します。 1. Go 言語でのデータベース機能 Go 言語でのデータベース操作は主に、database/sql パッケージを通じて実装されます。このパッケージは基本的なデータを提供します

Redis と PHP クラスター ソリューション: 高可用性とスケーラビリティを実現する方法 はじめに: Redis は、高速でスケーラブルなアプリケーションを構築するためによく使用される、オープン ソースの高性能インメモリ データベースです。一般的なサーバー側スクリプト言語として、PHP を Redis と併用して、高可用性とスケーラビリティのクラスター ソリューションを実現できます。この記事では、Redis と PHP を使用して高可用性とスケーラブルなクラスターを構築する方法を紹介し、コード例を通じて詳しく説明します。 1. Redis クラスター Re の構築、インストール、設定

Redis および Julia 言語を使用して高可用性クラスター機能を実装する方法 はじめに: インターネット ビジネスの発展に伴い、システムの可用性に対する要件はますます高くなっています。障害が発生した場合でもシステムがサービスを提供し続けることができるようにするために、高可用性はさまざまな業界で重要な要件の 1 つになっています。この記事では、Redis 言語と Julia 言語を使用して高可用性クラスター機能を実装する方法を紹介し、具体的なコード例を示します。 1. 高可用性クラスターとは何ですか? 高可用性クラスターは、複数のノードをまとめてシステム全体を形成します。

Redis は、高性能のオープンソース メモリ データ ストレージ サービスであり、その高速な読み取りおよび書き込み速度、永続的なストレージ、および複数のデータ構造のサポートにより、開発者の間でますます好まれています。ビジネスが成長し続けるにつれて、Redis のストレージ容量は需要を満たすことができなくなり、拡張する必要があります。この記事では、Redis クラスターの拡張計画とその実装の詳細について紹介します。 Redis クラスターの概念 Redis クラスターは、複数の Redis インスタンスを接続して大規模な Redis インスタンスのセットを形成することを指します。これにより、Redis が向上します。
