MYSQL数据库集群高可用和数据监控平台

1.环境准备(三个虚拟机都要做)

创建虚拟机并更改环境

vi /etc/selinux/config

重启后下载软件并且同步时间

yum install vim make gcc tree net-tools tar -y

yum update

安装好后

vim /etc/chrony.conf

timedatectl (可以用这个看一下)

三台机子完成后拍快照安装mysql,其中monitor虚拟机不用装

解压缩

tar xvf mysql-8.0.37-linux-glibc2.17-x86_64.tar.xz

cd mysql-8.0.37-linux-glibc2.17-x86_64

改变mysql的安装位置并创建用户(这里可以选择性配置)

软件初始化(root@......那里记得复制密码)

到这里从新打开一个终端(在当前 MobaXterm 的右键菜单中,选择 "Duplicate tab"(复制标签页)

新终端(密码粘贴之前复制的)

修改密码

alter user 'root'@'localhost' identified with mysql_native_password by '123456';

看一下数据库怎么样后关闭

最后一条指令kill -9 进程号中要替换上面自己的进程号(这里写错了应该是39150)

设置mysql的配置文件

vim /etc/my.cnf

client

port = 3306

socket = /tmp/mysql.sock

mysqld

port = 3306

basedir = /usr/local/mysql

datadir = /usr/local/mysql/data

tmpdir = /tmp

socket = /tmp/mysql.sock

character-set-server = utf8mb4

collation-server = utf8mb4_general_ci

default-storage-engine=INNODB

log_error = error.log

配置启动脚本
root@master1 \~# cd /usr/local/mysql/support-files

root@master1 support-files# cp -a mysql.server /etc/init.d/mysql

root@master1 support-files# vim /etc/init.d/mysql

root@master1 init.d# cd ~

root@master1 \~# vim ~/.bash_profile

root@master1 \~# source ~/.bash_profile

root@master1 \~# systemctl daemon-reload # 重载系统配置

root@master1 \~# systemctl start mysql

root@master1 \~# /usr/lib/systemd/systemd-sysv-install enable mysql # 开机启动

root@master1 \~# mysql -uroot -p

mysql> update mysql.user set host="%" where user="root";

mysql> flush privileges;

mysql> exit

2.msyql集群搭建

master1节点配置

root@master1 \~# systemctl stop mysql

root@master1 \~# vim /etc/my.cnf (直接在后面加)

  • 创建用于数据同步的账号m1

  • root@master1 \~# systemctl start mysql

    root@master1 \~# mysql -uroot -p

    mysql> create user 'mback'@'%' identified with mysql_native_password by '123456';

    mysql> grant replication slave on *.* to 'mback'@'%';

master2节点配置

基本一样,但是master2节点的server-id=2,不能和master1的server-id相同

剩下都完全一样就行

建立master1 节点主从关系
注意:这句在master2上执行

日志文件:mysql-bin-log.000001

日志数据点: 664

这个在master1 上写

change master to master_host='172.25.254.162',master_user='mback',master_password='123456',master_port=3306,master_log_file='mysql-bin-log.000001',master_log_pos=664; (ip替换成自己的master2ip,日志数据点也改成自己的)

start slave;

mysql> show slave status\G (这个建议稍微等一会再敲,他稍微需要点时间)

建立master2 节点主从关系

master1上

master2上

change master to master_host='172.25.254.161',master_user='mback',master_password='123456',master_port=3306,master_log_file='mysql-bin-log.000001',master_log_pos=664;

start slave;

mysql> show slave status\G

两个必须是yes

检测是否同步(两个虚拟机看一下一不一样)

master1(主)--master2(从)构建完毕

master2

master1

master1(从)--master2(主)构建完毕

3.Keepalived故障转移的高可用环境

master1节点配置

root@master1 \~# yum install keepalived -y

master1节点

root@master1 \~# vim /etc/keepalived/keepalived.conf

ip地址依然配自己的,网卡也是自己的

root@master1 \~# vim /etc/keepalived/chk_mysql.sh

#!/bin/bash

counter=$(netstat -na|grep "LISTEN"|grep "3306"|wc -l)

if "${counter}" -eq 0 ; then

killall keepalived

fi

root@master1 \~# chmod +x /etc/keepalived/chk_mysql.sh # 设置脚本执行权限

root@master1 \~# systemctl start keepalived

root@master1 \~# systemctl status keepalived (active running)

看一下成功了吗(注意看网卡那个位置有没有新的)

master2节点配置
复制代码
[root@master2 ~]# yum  install  keepalived -y

root@master2 \~# vim /etc/keepalived/keepalived.conf

复制代码
[root@master2 ~]# vim  /etc/keepalived/chk_mysql.sh
#!/bin/bash
复制代码
counter=$(netstat -na|grep "LISTEN"|grep "3306"|wc -l)
复制代码
if [ "${counter}" -eq 0 ]; then
复制代码
    killall keepalived
复制代码
fi
局部测试

master1

master2

master1

即使master1恢复后,VIP不会被强占

4.安装监控平台

monitor主机

root@monitor mysqld_exporter# vim .my.cnf # 注意为隐藏文件

client

user = exporter # 该账户需要再2台mysql节点新建

password = 123456 # 登录密码

host = 192.168.88.200 # 使用VIP访问

port = 3306

  • 2台mysql节点创建用户并授权

  • master1

master2

monitor节点操作

root@monitor \~# vim /usr/lib/systemd/system/mysqld_exporter.service

Unit

Description=https://prometheus.io

Service

Restart=on-failure

ExecStart=/usr/local/mysqld_exporter/mysqld_exporter --config.my-cnf=/usr/local/mysqld_exporter/.my.cnf --web.listen-address=:9104

Install

WantedBy=multi-user.target

刷新服务配置并启动服务

root@monitor \~# systemctl daemon-reload

root@monitor \~# systemctl start mysqld_exporter.service

root@monitor \~# systemctl enable mysqld_exporter.service

root@monitor \~# systemctl status mysqld_exporter.service

5.部署Promethues

monitor

root@monitor \~# vim /usr/lib/systemd/system/prometheus.service

root@monitor \~# systemctl daemon-reload

root@monitor \~# systemctl enable --now prometheus

root@monitor \~# systemctl status prometheus

root@monitor \~# vim /usr/local/prometheus/prometheus.yml

root@monitor \~# systemctl restart prometheus

部署Grafana
  • 下载并解压缩:

root@monitor \~# tar xvf prometheus-2.53.2.linux-amd64.tar.gz

root@monitor \~# yum install grafana-enterprise-11.1.2-1.x86_64.rpm -y

root@monitor \~# vim /etc/grafana/grafana.ini

到这里结束

相关推荐
你好潘先生2 小时前
别再记命令了,用 yeero do 说句人话就能跑脚本,而且不烧 token
服务器·python·命令行
orion5714 小时前
Missing Semester Class1:course overview and introduction of shell
linux
SkyWalking中文站18 小时前
认识 Horizon UI · 6/17:Trace 探索器
运维·监控·自动化运维
用户1204872216120 小时前
Linux驱动编译与加载
linux·嵌入式
程序员老赵21 小时前
服务器文件不想 SFTP 上传?Docker 跑个 File Browser,浏览器就能管理
服务器·docker·开源
火车叼位21 小时前
写给初级开发者:SSL、SSH、HTTPS 与证书体系全解析
运维
vivo互联网技术1 天前
从 10 分钟到 1 秒:ES 深度分页任意跳页的三轮优化实战
服务器·数据库·redis·elasticsearch·深度分页
用户805533698031 天前
Input 子系统架构:Core、Handler、Driver 三层是怎么协作的
linux·嵌入式
用户805533698031 天前
RK-Forge外设系列开篇 - 把板子从「能启动」变成「能用」:Ethernet/SPI/MMC 三个纯接线外设
linux·github·嵌入式