keepalived+mysql高可用
一.设置mysql同步信息
两节点安装msyql略
#配置节点1
1.配置权限
允许远程访问
mysql -u root -p
grant all on *.* to root@'%' identified by 'Root1212@#' with grant option;
flush privileges;
2.修改my.cnf
#作为主节点配置(节点1)
#作为主节点配置
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
# 作为从节点配置(节点2),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
3.开启同步(节点1)
mysql -P3306 -hxxx.xxx.xxx.xxx -uroot -p密码
CHANGE MASTER TOMASTER_HOST='10.10.16.50',MASTER_USER='root',MASTER_PASSWORD='Rootsql1212@#',MASTER_LOG_FILE='mysql-bin.000001',MASTER_LOG_POS=2959;
MASTER_HOST='10.10.16.50' 节点2的ip
MASTER_USER='root', 节点2的mysql用户名
MASTER_PASSWORD='密码',节点2的mysql密码
MASTER_LOG_FILE='mysql-bin.000014', 和 MASTER_LOG_POS=453768;;为节点2同步日志位置。
查看节点2的MASTER_LOG_FILE和MASTER_LOG_POS
#登录主节点2,mysql
mysql -P3306 -h10.10.16.50 -uroot -pRootsql1212@#
show master status

节点2配置主从,需要暂停同步stop slave,如果不暂停同步,则无法设置同步信息。
mysql -P3306 -hxx.xx.xx.xx -uroot -p密码#暂停同步
stop slave;#同步信息设置
CHANGE MASTER TOMASTER_HOST='10.10.16.44',MASTER_USER='root',MASTER_PASSWORD='密码',MASTER_LOG_FILE='binlog.000014',MASTER_LOG_POS=490354;#开启同步
start slave;
MASTER_HOST='10.10.16.44' 节点1的ip
MASTER_USER='root', 节点1的mysql用户名
MASTER_PASSWORD='密码',节点1的mysql密码
MASTER_LOG_FILE=binlog.000014 和 MASTER_LOG_POS=490354;为节点1同步日志位置。
查看节点1的MASTER_LOG_FILE和MASTER_LOG_POS
#登录主节点2,mysql
mysql -P3306 -h10.10.16.40 -uroot -pRootsql1212@#
show master status

#在mysql里面查看同步状态 Slave_IO_Running和Slave_SQL_Running需要均为Yes
show slave status\G;

二.安装keepalived
两节点服务器都安装keepalived
#编译安装
安装依赖
sudo apt install gcc # 安装gcc
sudo apt install make # 安装make
sudo apt install libssl-dev # 安装ssl编译依赖文件
sudo apt install libnfnetlink-dev # 安装libnfnetlink-dev
sudo apt install libnl-3-dev # 安装libnl-3-dev
sudo apt install libnl-genl-3-dev # 安装libnl-genl-3-dev
安装
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
cd /usr/local/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/sbin/keepalived /sbin/
sudo mkdir /etc/keepalived
sudo cp /usr/local/keepalived/etc/keepalived/keepalived.conf /etc/keepalived/
配置节点信息
节点1 :
vim /etc/keepalived/keepalived.conf
bal_defs {router_id MYSQL_HA #当前节点名
}
vrrp_instance VI_1 {state BACKUP #两台配置节点均为BACKUPinterface enahisic2i0 #绑定虚拟IP的网络接口virtual_router_id 51 #VRRP组名,两个节点的设置必须一样,以指明各个节点属于同一VRRP组priority 101 #节点的优先级,另一台优先级改低一点advert_int 1 #组播信息发送间隔,两个节点设置必须一样nopreempt #不抢占,只在优先级高的机器上设置即可,优先级低的机器不设置authentication { #设置验证信息,两个节点必须一致auth_type PASSauth_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|dhlb_kind DR #LVS集群模式 ,NAT|DR|TUNpersistence_timeout 60 #会话保持时间protocol TCP #使用的协议是TCP还是UDPreal_server 10.10.16.44 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 #健康检查端口}}
}
重启keepalived
systemctl daemon-reload
service keepalived restart
查看虚拟ip
ip addr show enahisic2i0

节点2:
vim /etc/keepalived/keepalived.conf
bal_defs {router_id MYSQL_HA #当前节点名
}
vrrp_instance VI_1 {state BACKUP #两台配置节点均为BACKUPinterface enahisic2i0 #绑定虚拟IP的网络接口virtual_router_id 51 #VRRP组名,两个节点的设置必须一样,以指明各个节点属于同一VRRP组priority 100 #节点的优先级,另一台优先级改低一点advert_int 1 #组播信息发送间隔,两个节点设置必须一样nopreempt #不抢占,只在优先级高的机器上设置即可,优先级低的机器不设置authentication { #设置验证信息,两个节点必须一致auth_type PASSauth_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|dhlb_kind DR #LVS集群模式 ,NAT|DR|TUNpersistence_timeout 60 #会话保持时间protocol TCP #使用的协议是TCP还是UDPreal_server 10.10.16.50 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 #健康检查端口}}
}
重启keepalived
systemctl daemon-reload
service keepalived restart
查看虚拟ip
ip addr show enahisic2i0
虚拟ip只存在一个节点上
测试是否成功:
mysql -P3306 -h192.168.1.111 -uroot -pRootsql1212@#
停止其中的一个节点mysql
查看ip是否漂移到另一个节点
ip addr show enahisic2i0
另外mysql是否还可以登录
mysql -P3306 -h192.168.1.111 -uroot -pRootsql1212@#
相关文章:

keepalived+mysql高可用
一.设置mysql同步信息两节点安装msyql略#配置节点11.配置权限允许远程访问mysql -u root -p grant all on *.* to root% identified by Root1212# with grant option; flush privileges;2.修改my.cnf#作为主节点配置(节点1)#作为主节点配置 server-id 1 …...

JAVA工具篇--1 Idea中 Gradle的使用
前言: 既然我们已经使用Maven 来完成对项目的构建,为什么还要使用Gradle 进行项目的构建;gradle和maven都可以作为java程序的构建工具,但两者还是有很大的不同之处的:1.可扩展性,gradle比较灵活,…...

弄懂自定义 Hooks 不难,改变开发认知有点不习惯
前言 我之前总结逻辑重用的时候,就一直在思考一个问题。 对于逻辑复用,render props 和 高阶组件都可以实现,同样官方说 Hooks 也可以实现,且还是在不增加额外的组件的情况下。 但是我在项目代码中,没有找到自定义 …...

Java面向对象基础
文章目录面向对象类注意事项内存机制构造器this关键字封装javabean格式成员变量和局部变量区别static静态关键字使用成员方法使用场景内存机制注意事项static应用:工具类static应用:代码块静态代码块实例代码块(用的比较少)static…...

基于python下selenium库实现交互式图片保存操作(批量保存浏览器中的图片)
Selenium是最广泛使用的开源Web UI(用户界面)自动化测试套件之一,可以通过编程与浏览量的交互式操作对网页进行自动化控制。基于这种操作进行数据保存操作,尤其是在图像数据的批量保存上占据优势。本博文基于selenium 与jupyterla…...

一:Datart的下载、本地运行
前言:本文只是个人在使用datart的一个记录,仅供参考。如果有不一样的地方,欢迎评论或私信进行交流。datart 是新一代数据可视化开放平台,支持各类企业数据可视化场景需求,如创建和使用报表、仪表板和大屏,进…...

Docker-compose
一.Docker-compose概述Docker-Compose项目是Docker官方的开源项目,负责实现对Docker容器集群的快速编排。Docker-Compose将所管理的容器分为三层,分别是 工程(project),服务(service)以及容器&a…...

经典文献阅读之--PLC-LiSLAM(面,线圆柱SLAM)
0. 简介 对于激光SLAM来说,现在越来越多的算法不仅仅局限于点线等简答特征的场景了,文章《PLC-LiSLAM: LiDAR SLAM With Planes, Lines,and Cylinders》说到,平面、线段与圆柱体广泛存在于人造环境中。为此作者提出了一个使用这些landmark的…...

计算组合数Cnk即从n个不同数中选出k个不同数共有多少种方法math.comb(n,k)
【小白从小学Python、C、Java】 【计算机等级考试500强双证书】 【Python-数据分析】 计算组合数Cnk 即从n个不同数中选出k个不同数共有多少种方法 math.comb(n,k) 以下python代码输出结果是? import math print("【执行】print(math.comb(3,1))") print(math.comb(…...
工厂设计模式
基本概念:为创建对象提供过渡接口,以便将创建对象的具体过程屏蔽隔离起来,达到提高灵活性的目的。分为三类:简单工厂模式Simple Factory:不利于产生系列产品;工厂方法模式Factory Method:又称为…...

IO多路转接 —— poll和epoll
文章目录1. poll1.1 poll的函数接口1.2 poll的简单测试程序1.3 poll的优缺点分析2. epoll2.1 epoll的函数接口2.2 epoll的工作原理2.3 epoll的工作模式(LT,ET)2.4 epoll的简易服务器实现(默认是LT工作模式)前言: 接上文讲述的select,它有缺点,…...

计算机网络整理-问答
1. 程序工作的时候网络各层的状态 如下图所示: 1. TCP 在进行三次握手的时候,IP 层和 MAC 层对应都有什么操作呢? TCP 三次握手是通过在传输层建立连接的一个过程,在这个过程中,TCP 和 IP 层、MAC 层都起到了重要的…...

JS 实现抛物线动画案例
相信大家都有浏览过,很多购物网站购物车的添加商品动画,今天,我们就手写一个简单的抛物线动画,先上案例: 一、绘制页面 我们这里简单实现,一个按钮,一个购物车图标,样式这里直接跳过…...

CSGO搬砖项目,23年最适合小白的项目!
大家好,我是阿阳 不懂的小伙伴,咱继续听我娓娓道来 steam搬砖主要涉及的是csgo游戏平台装备的一个搬运,比较很好理解,主要就是道具的搬运工,简单来讲就是,从国外steam游戏平台购买装备,再挂到…...

谈谈会话管理
客户端和服务器之间进行数据传输遵循的是HTTP协议, 此协议属于无状态协议(一次请求对应一次响应, 响应完之后断开连接), 服务器是无法跟踪客户端的请求, 通过cookie技术可以给客户端添加一个标识, 客户端之后发出的每次请求都会带着这个标识从而让服务器识别此客户端, 但由于co…...

Linux查看JVM FULL GC频率
查看系统的full gc频率,可以使用jstack命令一、采用top命令定位进程登录服务器,执行top命令,查看CPU占用情况,找到进程的pid二、使用jstack命令统计垃圾回收jstat -gc pid 5000即会每5秒一次显示进程号为pid的java进程的GC情况以上…...

java世界String的那些事
String的创建机理: 由于String在Java世界中使用过于频繁,Java为了避免在一个系统中产生大量的String对象,引入了字符串常量池。其运行机制是:创建一个字符串时,首先检查池中是否有值相同的字符串对象,如果…...

【图像配准】多图配准/不同特征提取算法/匹配器比较测试
前言 本文首先完成之前专栏前置博文未完成的多图配准拼接任务,其次对不同特征提取器/匹配器效率进行进一步实验探究。 各类算法原理简述 看到有博文[1]指出,在速度方面SIFT<SURF<BRISK<FREAK<ORB,在对有较大模糊的图像配准时&…...

2023金三银四季跳槽季,啃完这软件测试面试题,跳槽不就稳稳的了
前言 2023年也到来了,接近我们所说的“金三银四”也正在执行了,时间晃眼就过去了,有的人为了2023跳槽早早做足了准备,有的人在临阵磨刀,想必屏幕前的你也想在2023年涨薪吧,那么问题来了,怎么才…...

【C++详解】——vector类
📖 前言:本期介绍vector类。 目录🕒 1. vector的介绍🕒 2. vector的使用🕘 2.1 定义🕘 2.2 iterator🕘 2.3 空间增长🕘 2.4 增删查改🕒 2. vector的模拟实现🕘…...

未来机器人的大脑:如何用神经网络模拟器实现更智能的决策?
编辑:陈萍萍的公主一点人工一点智能 未来机器人的大脑:如何用神经网络模拟器实现更智能的决策?RWM通过双自回归机制有效解决了复合误差、部分可观测性和随机动力学等关键挑战,在不依赖领域特定归纳偏见的条件下实现了卓越的预测准…...

基于距离变化能量开销动态调整的WSN低功耗拓扑控制开销算法matlab仿真
目录 1.程序功能描述 2.测试软件版本以及运行结果展示 3.核心程序 4.算法仿真参数 5.算法理论概述 6.参考文献 7.完整程序 1.程序功能描述 通过动态调整节点通信的能量开销,平衡网络负载,延长WSN生命周期。具体通过建立基于距离的能量消耗模型&am…...

1.3 VSCode安装与环境配置
进入网址Visual Studio Code - Code Editing. Redefined下载.deb文件,然后打开终端,进入下载文件夹,键入命令 sudo dpkg -i code_1.100.3-1748872405_amd64.deb 在终端键入命令code即启动vscode 需要安装插件列表 1.Chinese简化 2.ros …...
生成 Git SSH 证书
🔑 1. 生成 SSH 密钥对 在终端(Windows 使用 Git Bash,Mac/Linux 使用 Terminal)执行命令: ssh-keygen -t rsa -b 4096 -C "your_emailexample.com" 参数说明: -t rsa&#x…...
Nginx server_name 配置说明
Nginx 是一个高性能的反向代理和负载均衡服务器,其核心配置之一是 server 块中的 server_name 指令。server_name 决定了 Nginx 如何根据客户端请求的 Host 头匹配对应的虚拟主机(Virtual Host)。 1. 简介 Nginx 使用 server_name 指令来确定…...
Spring AI 入门:Java 开发者的生成式 AI 实践之路
一、Spring AI 简介 在人工智能技术快速迭代的今天,Spring AI 作为 Spring 生态系统的新生力量,正在成为 Java 开发者拥抱生成式 AI 的最佳选择。该框架通过模块化设计实现了与主流 AI 服务(如 OpenAI、Anthropic)的无缝对接&…...
Java入门学习详细版(一)
大家好,Java 学习是一个系统学习的过程,核心原则就是“理论 实践 坚持”,并且需循序渐进,不可过于着急,本篇文章推出的这份详细入门学习资料将带大家从零基础开始,逐步掌握 Java 的核心概念和编程技能。 …...
根据万维钢·精英日课6的内容,使用AI(2025)可以参考以下方法:
根据万维钢精英日课6的内容,使用AI(2025)可以参考以下方法: 四个洞见 模型已经比人聪明:以ChatGPT o3为代表的AI非常强大,能运用高级理论解释道理、引用最新学术论文,生成对顶尖科学家都有用的…...

3-11单元格区域边界定位(End属性)学习笔记
返回一个Range 对象,只读。该对象代表包含源区域的区域上端下端左端右端的最后一个单元格。等同于按键 End 向上键(End(xlUp))、End向下键(End(xlDown))、End向左键(End(xlToLeft)End向右键(End(xlToRight)) 注意:它移动的位置必须是相连的有内容的单元格…...

html-<abbr> 缩写或首字母缩略词
定义与作用 <abbr> 标签用于表示缩写或首字母缩略词,它可以帮助用户更好地理解缩写的含义,尤其是对于那些不熟悉该缩写的用户。 title 属性的内容提供了缩写的详细说明。当用户将鼠标悬停在缩写上时,会显示一个提示框。 示例&#x…...