最新Ubuntu搭建Mysql+Keepalived高可用(双主热备)(2),从消息中间件看分布式系统的多种套路

最后

这份清华大牛整理的进大厂必备的redis视频、面试题和技术文档

祝大家早日进入大厂,拿到满意的薪资和职级~~~加油!!

感谢大家的支持!!

image.png

本文已被CODING开源项目:【一线大厂Java面试题解析+核心总结学习笔记+最新讲解视频+实战项目源码】收录

需要这份系统化的资料的朋友,可以点击这里获取

server-id = 1 #节点ID

log_bin = mysql-bin.log #日志

binlog_format = “ROW” #日志格式

auto_increment_increment = 2 #自增ID间隔(=节点数,防止ID冲突)

auto_increment_offset = 1 #自增ID起始值(节点ID)

binlog_ignore_db=mysql #不同步的数据库

binlog_ignore_db=information_schema

binlog_ignore_db=performance_schema

重启mysql

service mysql restart

mysql -u root -p

记录节点1的binlog日志位置

show master status;

mysql-bin.000001 245 mysql,information_schema,performance_schema

配置节点2

vim /etc/mysql/my.cnf

server-id = 2

log_bin = mysql-bin.log

relay_log = mysql-relay-bin.log #中继日志

log_slave_updates = ON #中继日志执行后,变化计入日志

read_only = 0

binlog_format = “ROW”

auto_increment_increment = 2

auto_increment_offset = 2

binlog_ignore_db=mysql

binlog_ignore_db=information_schema

binlog_ignore_db=performance_schema

replicate_ignore_db=mysql

replicate_ignore_db=information_schema

replicate_ignore_db=performance_schema

配置主从

mysql -u root -p

CHANGE MASTER TO

MASTER_HOST=‘192.168.1.21’,

MASTER_USER=‘root’,

MASTER_PASSWORD=‘root’,

MASTER_LOG_FILE=‘mysql-bin.000001’,

MASTER_LOG_POS=245;

#开启同步

start slave

#查看同步状态 Slave_IO_Running和Slave_SQL_Running需要均为Yes

show slave status;

记录节点2的binlog日志位置

show master status;

mysql-bin.000001 1029 mysql,information_schema,performance_schema

配置主主(节点1)

vim /etc/mysql/my.cnf

relay_log = mysql-relay-bin.log

log_slave_updates = ON

read_only = 0

replicate_ignore_db=mysql

replicate_ignore_db=information_schema

replicate_ignore_db=performance_schema

开启同步

mysql -u root -p

CHANGE MASTER TO

MASTER_HOST=‘192.168.1.20’,

MASTER_USER=‘root’,

MASTER_PASSWORD=‘root’,

MASTER_LOG_FILE=‘mysql-bin.000001’,

MASTER_LOG_POS=1029;

#开启同步

start slave

#查看同步状态 Slave_IO_Running和Slave_SQL_Running需要均为Yes

show slave status;

异常处理

Could not initialize master info structure, more error messages can be found in the MySQL error log

解决:reset slave

安装配置Keepalived

安装Keepalived

#依赖

sudo apt-get install -y libssl-dev

sudo apt-get install -y openssl

sudo apt-get install -y libpopt-dev

sudo apt-get install -y libnl-dev libnl-3-dev libnl-genl-3.dev

apt-get install daemon

apt-get install libc-dev

apt-get install libnfnetlink-dev

apt-get install libnl-genl-3.dev

#安装

apt-get install keepalived

#编译安装

cd /usr/local

wget https://www.keepalived.org/software/keepalived-2.2.2.tar.gz

tar -zxvf keepalived-2.2.2.tar.gz

mv keepalived-2.2.2 keepalived

./configure --prefix=/usr/local/keepalived

sudo make && make install

#开启日志

sudo vim /etc/rsyslog.d/50-default.conf

.=info;.=notice;*.=warn;\

auth,authpriv.none;\

cron,daemon.none;\

mail,news.none -/var/log/messages

sudo service rsyslog restart

tail -f /var/log/messages

sudo mkdir /etc/sysconfig

sudo cp /usr/local/keepalived/etc/sysconfig/keepalived /etc/sysconfig/

sudo cp /usr/local/keepalived/etc/rc.d/init.d/keepalived /etc/init.d/

sudo cp /usr/local/keepalived/sbin/keepalived /sbin/

sudo mkdir /etc/keepalived

sudo cp /usr/local/keepalived/etc/keepalived/keepalived.conf /etc/keepalived/

配置节点信息


节点1 192.168.1.21

vim /etc/keepalived/keepalived.conf

global_defs {

router_id MYSQL_HA  #当前节点名

}

vrrp_instance VI_1 {

state BACKUP #两台配置节点均为BACKUP

interface eth0 #绑定虚拟IP的网络接口

virtual_router_id 51 #VRRP组名,两个节点的设置必须一样,以指明各个节点属于同一VRRP组

priority 101 #节点的优先级,另一台优先级改低一点

advert_int 1 #组播信息发送间隔,两个节点设置必须一样

nopreempt #不抢占,只在优先级高的机器上设置即可,优先级低的机器不设置

authentication { #设置验证信息,两个节点必须一致

auth_type PASS

auth_pass 123456

}

virtual_ipaddress { #指定虚拟IP,两个节点设置必须一样

192.168.1.111

}

}

virtual_server 192.168.1.111 3306 { #linux虚拟服务器(LVS)配置

delay_loop 2 #每个2秒检查一次real_server状态

lb_algo wrr #LVS调度算法,rr|wrr|lc|wlc|lblc|sh|dh

lb_kind DR #LVS集群模式 ,NAT|DR|TUN

persistence_timeout 60 #会话保持时间

protocol TCP #使用的协议是TCP还是UDP

real_server 192.168.1.21 3306 {

weight 3 #权重

notify_down /usr/local/bin/mysql.sh #检测到服务down后执行的脚本

TCP_CHECK {

connect_timeout 10 #连接超时时间

nb_get_retry 3 #重连次数

delay_before_retry 3 #重连间隔时间

connect_port 3306 #健康检查端口

}

}

}

节点2 192.168.1.20

vim /etc/keepalived/keepalived.conf

global_defs {

router_id MYSQL_HA  #当前节点名

}

vrrp_instance VI_1 {

state BACKUP #两台配置节点均为BACKUP

interface eth0 #绑定虚拟IP的网络接口

virtual_router_id 51 #VRRP组名,两个节点的设置必须一样,以指明各个节点属于同一VRRP组

priority 100 #节点的优先级,另一台优先级改低一点

advert_int 1 #组播信息发送间隔,两个节点设置必须一样

nopreempt #不抢占,只在优先级高的机器上设置即可,优先级低的机器不设置

authentication { #设置验证信息,两个节点必须一致

auth_type PASS

auth_pass 123456

}

virtual_ipaddress { #指定虚拟IP,两个节点设置必须一样

192.168.1.111

}

}

读者福利

由于篇幅过长,就不展示所有面试题了,感兴趣的小伙伴

35K成功入职:蚂蚁金服面试Java后端经历!「含面试题+答案」

35K成功入职:蚂蚁金服面试Java后端经历!「含面试题+答案」

35K成功入职:蚂蚁金服面试Java后端经历!「含面试题+答案」

更多笔记分享

35K成功入职:蚂蚁金服面试Java后端经历!「含面试题+答案」

本文已被CODING开源项目:【一线大厂Java面试题解析+核心总结学习笔记+最新讲解视频+实战项目源码】收录

需要这份系统化的资料的朋友,可以点击这里获取

{ #指定虚拟IP,两个节点设置必须一样

192.168.1.111

}

}

读者福利

由于篇幅过长,就不展示所有面试题了,感兴趣的小伙伴

[外链图片转存中…(img-hqqstXvG-1715651187909)]

[外链图片转存中…(img-03S5buyr-1715651187909)]

[外链图片转存中…(img-zQhiNVLL-1715651187909)]

更多笔记分享

[外链图片转存中…(img-aepcYo77-1715651187910)]

本文已被CODING开源项目:【一线大厂Java面试题解析+核心总结学习笔记+最新讲解视频+实战项目源码】收录

需要这份系统化的资料的朋友,可以点击这里获取

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值