mysql 5.5 + mha 安装配置+vip ip 漂移_MySQL
一、概述
MHA是一位日本人用Perl写的一套MySQL故障切换方案,来保证数据库系统的高可用.在宕机的时间内(通常10—60秒内),完成故障切换,部署MHA,可避免主从一致性问题,节约购买新服务器的费用,不影响服务器性能,易安装,不改变现有部署。
还支持在线切换,从当前运行master切换到一个新的master上面,只需要很短的时间(0.5-2秒内),此时仅仅阻塞写操作,并不影响读操作,便于主机硬件维护。
二、mha 管理节点的安装
yum install perl-DBD-MySQL /perl-Config-Tiny perl-Log-Dispatch /perl-Parallel-ForkManager -yyum install perl-Time-HiRes perl-Parallel-ForkManager -ywget http://mysql-master-ha.googlecode.com/files/mha4mysql-manager-0.55-0.el6.noarch.rpmwget http://mysql-master-ha.googlecode.com/files/mha4mysql-node-0.54-0.el6.noarch.rpmrpm -ivh mha4mysql-node-0.54-0.el6.noarch.rpmrpm -ivh mha4mysql-manager-0.55-0.el6.noarch.rpm
mkdir /etc/masterhavi /etc/masterha_default.cnf [server default]user=managerpassword=test_2014ping_interval=1repl_user=reprepl_password=rep_2014
ssh 证书安装:
root 用户下执行:
ssh-keygen -t rsa
拷贝 id_rsa.pub 到数据库节点机器上的/tmp 目录下,在数据库节点机器上执行:
cd /root/.sshcat /tmp/id_rsa.put >>authorized_keyschmod 600 authorized_keys
三、mha 数据库节点的安装
wget http://mysql-master-ha.googlecode.com/files/mha4mysql-node-0.54-0.el6.noarch.rpmyum install perl-DBD-MySQL -yrpm -ivh mha4mysql-node-0.54-0.el6.noarch.rpm
在数据库节点上以root 用户执行:
ssh-keygen -t rsa
分别拷贝id_rsa.pub 到对方机器的/tmp 目录下,然后分别执行:
cd /root/.sshcat /tmp/id_rsa.put >>authorized_keyschmod 600 authorized_keys
四、vip add 配置
在master 上执行下面命令(第一次启用必须配置手动配置vip address):
ifconfig eth1:2 10.10.0.102/16
五、mha 配置文件与故障转移脚本
在 mha 管理节点上编辑配置文件:
vi /etc/masterha/test.conf [server default]ssh_user=rootping_interval=1report_script=/usr/local/bin/send_reportmaster_ip_failover_script=/usr/local/bin/master_ip_failovermaster_ip_online_change_script=/usr/local/bin/master_ip_failover[server1]hostname=10.10.0.101master_binlog_dir=/log/mysql_testcandidate_master=1port=3306ssh_port=22[server2]hostname=10.10.0.100master_binlog_dir=/log/mysql_testcandidate_master=1port=3306ssh_port=22
六、mysql 主从配置
主从执行:
mysql>grant replication slave on *.* to rep@'10.10.%' identified by 'rep_2014' ;mysql>grant all on *.* to manager@'10.10.%' identified by 'test_2014' ;mysql>flush privileges;
主上执行:
mysql>show master status;
从上执行:
mysql>change master to master_host='10.10.0.101',master_port=3306,master_user='rep',master_password='rep_2014', master_log_file='mysql-bin.000004',master_log_pos=402; mysql> start slave;mysql> stop slave;mysql> reset slave;mysql> show slave status/G;
七、mha 操作命令
测试ssh 配置:
/usr/bin/masterha_check_ssh --conf=/etc/masterha/test.conf
测试复制:
/usr/bin/masterha_check_repl --conf=/etc/masterha/test.conf
启用 mha :
masterha_manager --conf=/etc/masterha/test.conf
master 切换:
masterha_master_switch --master_state=alive --conf=/etc/masterha/test.conf
八、脚本
master_ip_failover 脚本:
cat /usr/local/bin/master_ip_failover#!/usr/bin/env perluse strict;use warnings FATAL => 'all';use Getopt::Long;my ( $command, $ssh_user, $orig_master_host, $orig_master_ip, $orig_master_port, $new_master_host, $new_master_ip, $new_master_port);my $vip = '10.10.0.102/16'; # Virtual IPmy $key = "2";my $ssh_start_vip = "/sbin/ifconfig eth1:$key $vip";my $ssh_stop_vip = "/sbin/ifconfig eth1:$key down";$ssh_user = "root";GetOptions( 'command=s' => /$command, 'ssh_user=s' => /$ssh_user, 'orig_master_host=s' => /$orig_master_host, 'orig_master_ip=s' => /$orig_master_ip, 'orig_master_port=i' => /$orig_master_port, 'new_master_host=s' => /$new_master_host, 'new_master_ip=s' => /$new_master_ip, 'new_master_port=i' => /$new_master_port,);exit &main();sub main { print "/n/nIN SCRIPT TEST====$ssh_stop_vip==$ssh_start_vip===/n/n"; if ( $command eq "stop" || $command eq "stopssh" ) { # $orig_master_host, $orig_master_ip, $orig_master_port are passed. # If you manage master ip address at global catalog database, # invalidate orig_master_ip here. my $exit_code = 1; eval { print "Disabling the VIP on old master: $orig_master_host /n"; &stop_vip(); $exit_code = 0; }; if ($@) { warn "Got Error: $@/n"; exit $exit_code; } exit $exit_code; } elsif ( $command eq "start" ) { # all arguments are passed. # If you manage master ip address at global catalog database, # activate new_master_ip here. # You can also grant write access (create user, set read_only=0, etc) here. my $exit_code = 10; eval { print "Enabling the VIP - $vip on the new master - $new_master_host /n"; &start_vip(); $exit_code = 0; }; if ($@) { warn $@; exit $exit_code; } exit $exit_code; } elsif ( $command eq "status" ) { print "Checking the Status of the script.. OK /n"; `ssh $ssh_user/@cluster1 /" $ssh_start_vip /"`; exit 0; } else { &usage(); exit 1; }}# A simple system call that enable the VIP on the new mastersub start_vip() { `ssh $ssh_user/@$new_master_host /" $ssh_start_vip /"`;}# A simple system call that disable the VIP on the old_mastersub stop_vip() { `ssh $ssh_user/@$orig_master_host /" $ssh_stop_vip /"`;}sub usage { print "Usage: master_ip_failover --command=start|stop|stopssh|status --orig_master_host=host --orig_master_ip=ip --orig_master_port=port --new_master_host=host --new_master_ip=ip --new_master_port=port/n";}
cat send_report #!/usr/bin/perl# Copyright (C) 2011 DeNA Co.,Ltd.## This program is free software; you can redistribute it and/or modify# it under the terms of the GNU General Public License as published by# the Free Software Foundation; either version 2 of the License, or# (at your option) any later version.## This program is distributed in the hope that it will be useful,# but WITHOUT ANY WARRANTY; without even the implied warranty of# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the# GNU General Public License for more details.## You should have received a copy of the GNU General Public License# along with this program; if not, write to the Free Software# Foundation, Inc.,# 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA## Note: This is a sample script and is not complete. Modify the script based on your environment.use strict;use warnings FATAL => 'all';use Getopt::Long;#new_master_host and new_slave_hosts are set only when recovering master succeededmy ( $dead_master_host, $new_master_host, $new_slave_hosts, $subject, $body );GetOptions( 'orig_master_host=s' => /$dead_master_host, 'new_master_host=s' => /$new_master_host, 'new_slave_hosts=s' => /$new_slave_hosts, 'subject=s' => /$subject, 'body=s' => /$body,);# Do whatever you want hereexit 0;

热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

Video Face Swap
使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热门文章

热工具

记事本++7.3.1
好用且免费的代码编辑器

SublimeText3汉化版
中文版,非常好用

禅工作室 13.0.1
功能强大的PHP集成开发环境

Dreamweaver CS6
视觉化网页开发工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

热门话题

全表扫描在MySQL中可能比使用索引更快,具体情况包括:1)数据量较小时;2)查询返回大量数据时;3)索引列不具备高选择性时;4)复杂查询时。通过分析查询计划、优化索引、避免过度索引和定期维护表,可以在实际应用中做出最优选择。

InnoDB的全文搜索功能非常强大,能够显着提高数据库查询效率和处理大量文本数据的能力。 1)InnoDB通过倒排索引实现全文搜索,支持基本和高级搜索查询。 2)使用MATCH和AGAINST关键字进行搜索,支持布尔模式和短语搜索。 3)优化方法包括使用分词技术、定期重建索引和调整缓存大小,以提升性能和准确性。

是的,可以在 Windows 7 上安装 MySQL,虽然微软已停止支持 Windows 7,但 MySQL 仍兼容它。不过,安装过程中需要注意以下几点:下载适用于 Windows 的 MySQL 安装程序。选择合适的 MySQL 版本(社区版或企业版)。安装过程中选择适当的安装目录和字符集。设置 root 用户密码,并妥善保管。连接数据库进行测试。注意 Windows 7 上的兼容性问题和安全性问题,建议升级到受支持的操作系统。

聚集索引和非聚集索引的区别在于:1.聚集索引将数据行存储在索引结构中,适合按主键查询和范围查询。2.非聚集索引存储索引键值和数据行的指针,适用于非主键列查询。

MySQL是一个开源的关系型数据库管理系统。1)创建数据库和表:使用CREATEDATABASE和CREATETABLE命令。2)基本操作:INSERT、UPDATE、DELETE和SELECT。3)高级操作:JOIN、子查询和事务处理。4)调试技巧:检查语法、数据类型和权限。5)优化建议:使用索引、避免SELECT*和使用事务。

MySQL 数据库中,用户和数据库的关系通过权限和表定义。用户拥有用户名和密码,用于访问数据库。权限通过 GRANT 命令授予,而表由 CREATE TABLE 命令创建。要建立用户和数据库之间的关系,需创建数据库、创建用户,然后授予权限。

MySQL 和 MariaDB 可以共存,但需要谨慎配置。关键在于为每个数据库分配不同的端口号和数据目录,并调整内存分配和缓存大小等参数。连接池、应用程序配置和版本差异也需要考虑,需要仔细测试和规划以避免陷阱。在资源有限的情况下,同时运行两个数据库可能会导致性能问题。

数据集成简化:AmazonRDSMySQL与Redshift的零ETL集成高效的数据集成是数据驱动型组织的核心。传统的ETL(提取、转换、加载)流程复杂且耗时,尤其是在将数据库(例如AmazonRDSMySQL)与数据仓库(例如Redshift)集成时。然而,AWS提供的零ETL集成方案彻底改变了这一现状,为从RDSMySQL到Redshift的数据迁移提供了简化、近乎实时的解决方案。本文将深入探讨RDSMySQL零ETL与Redshift集成,阐述其工作原理以及为数据工程师和开发者带来的优势。
