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   到这里结束