利用Keepalived构建高可用的MySQL
公司大牛让用keepalived构建高可用的MySQL,在网上看到一篇很完整的文章,于是乎照着前辈的足迹,加上自己补充。如上述均正确配置
前言:公司大牛让用keepalived构建高可用的MySQL,在网上看到一篇很完整的文章,于是乎照着前辈的足迹,加上自己补充。
环境拓扑如下:
MySQL-VIP:192.168.1.150
MySQL-master1:192.168.1.151
MySQL-master2:192.168.1.152
OS版本:RedHat 5.4
MySQL版本:5.0.77
Keepalived版本:1.1.20
一、MySQL master-master的安装及配置
1、安装mysql
#yum install mysql-server -y \\为了节省时间,这里两台server都直接yum装,希望你配好了yum源。
2、修改配置文件
On server1:
#vim /etc/my.cnf
[mysqld]
server-id = 10
log-bin = mysql-bin
replicate-do-db = ccledb
auto-increment-increment = 2
auto-increment-offset = 1
On server2 :
#vim /etc/my.cnf
[mysqld]
server-id = 20
log-bin = mysql-bin
replicate-do-db = ccledb
auto-increment-increment = 2
auto-increment-offset = 2
3、建立授权用户
On server1:
mysql> grant replication client,replication slave on *.* to cclo1@’192.168.1.%’ identified by ‘123456’;
On server2:
mysql> grant replication client,replication slave on *.* to cclo2@’192.168.1.%’ identified by ‘123456’;
4、指定主服务器
On server1
mysql> show master status;
+------------------+----------+--------------+------------------+
| File | Position | Binlog_Do_DB | Binlog_Ignore_DB |
+------------------+----------+--------------+------------------+
| MySQL-bin.000003 | 374 | | |
+------------------+----------+--------------+------------------+
1 row in set (0.00 sec)
mysql> change master to master_host='192.168.1.152',master_user='cclo2',master_password='123456',master_log_file='mysql-bin.000003',master_log_pos=374;
Query OK, 0 rows affected (0.05 sec)
On server2
mysql> show master status;
+------------------+----------+--------------+------------------+
| File | Position | Binlog_Do_DB | Binlog_Ignore_DB |
+------------------+----------+--------------+------------------+
| MySQL-bin.000003 | 374 | | |
+------------------+----------+--------------+------------------+
1 row in set (0.00 sec)
mysql> change master to master_host='192.168.1.151',master_user='cclo1',master_password='123456',master_log_file='mysql-bin.000003',master_log_pos=374;
Query OK, 0 rows affected (0.05 sec)
5、开启主主服务
mysql> start slave; \\两台server分别执行
MySQL> show slave status\G \\查看主主状态
Slave_IO_Running: Yes
Slave_SQL_Running: Yes \\如果此2项都为yes,master-master配置即成功
如上述均正确配置,现在在任何一台MySQL上更新数据都会同步到另一台MySQL。
二、keepalived安装及配置
1、192.168.1.151服务器上keepalived安装及配置
安装keepalived
#tar zxvf keepalived-1.1.20.tar.gz
#cd keepalived-1.1.20
#./configure --prefix=/usr/local/keepalived --with-kernel-dir=/usr/src/kernels/2.6.18-164.el5-i686
\\此处一定确保你的linux中有/usr/src/kernels/2.6.18-164.el5-i686这个目录,如果没有请安装kernel- devel包,建议最好是下载和你的linux系统内核版本相同的devel包安装(一般安装镜像有),此处直接#yum install -y kernel-devel
#make && make install
配置keepalived
此处需新建一个配置文件,默认情况下keepalived启动时会去/etc/keepalived目录下找配置文件
#mkdir /etc/keepalived
#vim /etc/keepalived/keepalived.conf \\配置文件内容如下:
! Configuration File for keepalived
global_defs {
notification_email {
cclo@cer.cn
}
notification_email_from cclo@cer.cn
smtp_server 127.0.0.1
smtp_connect_timeout 30
router_id MySQL-ha
}
vrrp_instance VI_1 {
state BACKUP #两台配置此处均是BACKUP
interface eth0
virtual_router_id 51
priority 100 #优先级,另一台改为90
advert_int 1
nopreempt #不主动抢占资源,只在优先级高的机器上设置即可,优先级低的机器不设置
authentication {
auth_type PASS
auth_pass 1111
}
virtual_ipaddress {
192.168.1.150
}
}
virtual_server 192.168.1.150 3306 {
delay_loop 2 #每个2秒检查一次real_server状态
lb_algo wrr #LVS算法
lb_kind DR #LVS模式
persistence_timeout 60 #会话保持时间
protocol TCP
real_server 192.168.1.151 3306 {
weight 3
notify_down /usr/local/my/my.sh #检测到服务down后执行的脚本
TCP_CHECK {
connect_timeout 10 #连接超时时间
nb_get_retry 3 #重连次数
delay_before_retry 3 #重连间隔时间
connect_port 3306 #健康检查端口
}
}
编写检测服务down后所要执行的脚本:
#vim /usr/local/my/my.sh
#!/bin/sh
pkill keepalived
#chmod +x /usr/local/my/my.sh
注:此脚本是上面配置文件notify_down选项所用到的,keepalived使用notify_down选项来检查real_server的服务状态,当发现real_server服务故障时,便触发此脚本;我们可以看到,脚本就一个命令,通过pkill keepalived强制杀死keepalived进程,从而实现了MySQL故障自动转移。另外,,我们不用担心两个MySQL会同时提供数据更新操作,因为每台MySQL上的keepalived的配置里面只有本机MySQL的IP+VIP,而不是两台MySQL的IP+VIP
启动keepalived:
#/usr/local/keepalived/sbin/keepalived –D
#ps -aux | grep keepalived
测试
找一台局域网PC,然后去ping MySQL的VIP,这时候MySQL的VIP是可以ping的通的
停止MySQL服务,#ps -aux | grep keepalived 看keepalived健康检查程序是否会触发我们编写的脚本

ホット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)

ホットトピック









Golang は、開発者が高可用性の分散システムを実装するのに役立つ、効率的で簡潔かつ安全なプログラミング言語です。この記事では、Golang が高可用性分散システムを実装する方法を検討し、いくつかの具体的なコード例を示します。分散システムの課題 分散システムは、複数の参加者が協力するシステムです。分散システムの参加者は、地理的位置、ネットワーク、組織構造などの複数の側面で分散された異なるノードである場合があります。分散システムを実装する場合、次のような多くの課題に対処する必要があります。

Linux と Docker: 高可用性コンテナ クラスターを実装するにはどうすればよいですか?要約: コンテナテクノロジーの発展に伴い、アプリケーションをコンテナに徐々に導入する企業が増えています。実稼働環境では、コンテナー クラスターの高可用性を実現することが重要です。この記事では、Linux と Docker を使用して高可用性コンテナ クラスターを構築する方法を紹介し、コード例を通じて具体的な実装方法を示します。 DockerSwarm クラスターの構築 DockerSwarm は、Docker によって提供されるネイティブ コンテナー クラスター管理です。

クラウド コンピューティングとコンテナ化テクノロジの急速な発展に伴い、コンテナ オーケストレーション システムは、最新のアプリケーションの展開と管理の重要な部分となっています。コンテナ オーケストレーション システムは、複数のコンテナを自動的にスケジュール、デプロイ、管理できるため、高可用性とスケーラビリティが実現します。数あるプログラミング言語の中でも、Go 言語はその強力な同時実行機能と高いパフォーマンスにより広く注目を集めており、Docker や Kubernetes などの多くの有名なコンテナ オーケストレーション システムで使用されています。この記事では、Go 言語を使用して高可用性コンテナ オーケストレーション システムを開発する方法を紹介します。

分散データベース アーキテクチャを使用して可用性の高い MySQL クラスターを構築する方法 インターネットの発展に伴い、データベースの高可用性とスケーラビリティに対する要求がますます高まっています。分散データベース アーキテクチャは、これらのニーズを解決する効果的な方法の 1 つとなっています。この記事では、分散データベース アーキテクチャを使用して高可用性 MySQL クラスターを構築する方法を紹介し、関連するコード例を示します。 MySQL マスター/スレーブ レプリケーション クラスターの構築 MySQL マスター/スレーブ レプリケーションは、MySQL が提供する基本的な高可用性ソリューションです。マスター/スレーブ レプリケーションを通じて、データを

Java で高可用性と負荷分散を実現する方法 今日のインターネット時代では、高可用性と負荷分散は、安定した信頼性の高いシステムを構築するための重要な要素の 1 つです。広く使用されているプログラミング言語である Java には、高可用性と負荷分散の実現に役立つライブラリとツールが豊富にあります。この記事では、Java で高可用性と負荷分散を実装する方法を紹介し、具体的なコード例を示します。 1. 高可用性 高可用性とは、どのような状況でもシステムが長期間安定した稼働を維持できることを意味します。 Java では次のことができます

インターネットの急速な発展に伴い、より多くのデータを保存し、処理する必要があります。データのセキュリティと信頼性を確保するために、分散ストレージ システムの重要性がますます高まっています。この記事では、Go 言語を使用して高可用性分散ストレージ システムを開発する方法を紹介し、実際の主要な概念とテクノロジのいくつかを探ります。始める前に、まず分散ストレージ システムの基本原理を理解しましょう。分散ストレージ システムは複数のストレージ ノードで構成され、各ノードはデータの一部を独立して保存します。データの高可用性を確保するために、システムは次のことを行います。

インターネットの急速な発展に伴い、大規模アプリケーションのパフォーマンス要件はますます高くなっています。分散キャッシュ ストレージ システムは、アプリケーションのパフォーマンス、スケーラビリティ、信頼性を向上できる一般的なソリューションです。この記事では、Go 言語開発で可用性の高い分散キャッシュ ストレージ システムを実装する方法を検討します。 1. 背景の紹介 分散キャッシュ ストレージ システムは、大規模アプリケーションの重要なインフラストラクチャです。データをメモリに保存し、データ レプリケーションやデータ シャーディングなどのテクノロジーを通じて読み取りを高速化します。

Linux で高可用性 NAT ゲートウェイを構成する方法 概要: ネットワーク アドレス変換 (NAT) は、プライベート ネットワークの IP アドレスをパブリック ネットワークの IP アドレスに変換するために使用される一般的なネットワーク テクノロジです。 Linux システムでは、高可用性 NAT ゲートウェイを構成すると、ネットワークの可用性と信頼性が向上します。この記事では、Keepalived ツールと iptables ツールを使用して、Linux 上で高可用性 NAT ゲートウェイを構成する方法を紹介します。キーワード: NAT、高可用性、Keepalived、i
