centos7/redhat7 Mysql搭建主主集群+Keepalived高可用

一、在两台服务器上部署mysql:
1、下载mysql(新版本是5.7.38):
https://downloads.mysql.com/archives/community/
2、安装mysql:
查看是否安装了依赖:rpm –qa | grep libaio
tar xvf mysql-5.7.27-linux-glibc2.12-x86_64.tar.gz
mv mysql-5.7.27-linux-glibc2.12-x86_64 mysql
mkdir /data/mysqldata
创建mysql组及mysql用户,并赋权:
groupadd mysql
useradd -r -g mysql mysql
chown -R mysql:mysql /data/mysql
chown -R mysql:mysql /data/mysqldata
修改mysql配置文件:vi /etc/my.cnf (把原先的my.cnf中的内容都注释掉,再将以下内容copy到my.cnf中)
[mysqld]
basedir=/data/mysql
datadir=/data/mysqldata
port = 3306
socket=/tmp/mysql.sock

symbolic-links=0
log-error=/var/log/mysql/mysqld.log
pid-file=/tmp/mysqld/mysqld.pid
sql_mode='STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION'

[client]
default-character-set=utf8mb4

[mysql]
default-character-set=utf8mb4

[mysqld]
log-bin=mysql-bin
binlog-format=ROW
server_id=1
max_connections=1500
lower_case_table_names=1
init_connect='SET collation_connection = utf8mb4_general_ci'
init_connect='SET NAMES utf8mb4'
character-set-server=utf8mb4
collation-server=utf8mb4_general_ci
skip-character-set-client-handshake

创建mysql所需文件:
cd /tmp
touch mysql.sock
chown mysql:mysql mysql.sock
chmod 755 mysql.sock
 
cd /tmp
mkdir mysqld
cd mysqld
touch mysqld.pid
cd ..
chown -R mysql:mysql mysqld
cd mysqld
chmod 755 mysqld.pid
 
mkdir /var/log/mysql
touch /var/log/mysql/mysqld.log
chown -R mysql:mysql /var/log/mysql
cd /var/log/mysql
chmod 755 mysqld.log
初始化数据库:
cd /data/mysql/bin/
./mysqld --initialize --user=mysql --basedir=/data/mysql --datadir=/data/mysqldata
cd /data/mysql/bin/ 
./mysqld_safe --user=mysql & (启动后过个几秒,按回车即可回到命令行)
查询mysql登录密码:cat /var/log/mysql/mysqld.log | grep -i pass
登录mysql并修改密码、授权远程连接:
cd /data/mysql/bin/
./mysql -uroot -p
set password=password("Mysql#$123");
GRANT ALL PRIVILEGES ON *.* TO 'root'@'%' IDENTIFIED BY 'Mysql#$123' WITH GRANT OPTION;
ALTER USER 'root'@'%' IDENTIFIED BY 'Mysql#$123';
FLUSH PRIVILEGES;

设置开机自启动:
cp -a /data/mysql/support-files/mysql.server  /etc/init.d/mysql
chkconfig --add mysql
chkconfig --list mysql
添加快捷方式:
ln -s /data/mysql/bin/mysql /usr/bin
mysql服务启动或停止命令:
service mysql start
service mysql stop

二、配置mysql主主集群:
1、将B机器的mysql配置文件my.cnf的server-id设置为2,然后重启mysql服务,mysql –uroot –p进入数据库:
Mysql>show master status;(记住此时的File名称和Position)
2、进入A机器的数据库:
Mysql>show master status;(记住此时的File名称和Position)
在B机器的数据库中运行(如果mysql不是使用的3306端口,则需要加master_port=端口参数,不加的话,默认使用3306端口进行主主集群的配置):
mysql> change master to
     -> master_host='A机器IP',
     -> master_user='root',
     -> master_password='root密码',
     -> master_log_file='A机器File名称',
     -> master_log_pos=A机器Position;
mysql> start  slave;
在A机器的数据库中运行:
mysql> change  master to
     -> master_host='B机器IP',
     -> master_user='root',
     -> master_password='root密码',
     -> master_log_file='B机器File名称',
     -> master_log_pos=B机器Position;
mysql> start  slave;
两台机器都执行:Mysql>show slave status\G(主主同步配置完毕,查看同步状态Slave_IO_Running和Slave_SQL_Running是YES说明主主同步成功)
测试主主同步:两台机器分别创建不同名称的数据库,然后两台进行都运行mysql> show databases;
,查看这两台数据库中是不是都存在这两个刚刚创建的数据库名称,有,则表示均能读写并且做到了数据同步,是成功的表示。

三、配置keepalived:
两台机器都安装:yum -y install keepalived
设置开机自启:systemctl enable keepalived
A机器配置:
vi /etc/keepalived/keepalived.conf
# 清空keepalived.conf 中的内容,copy如下内容 
global_defs {
            #vrrp_strict # 注释或者删除了
        }
        vrrp_instance VI_1 {
            state MASTER         # 初始状态
            interface ens224     # ip a查看网卡名称,选择当前机器服务IP所在的网卡名称
            virtual_router_id 51 # 虚拟路由ID,同集群中ID必须一样,且同集群唯一
            priority 101         # 优先级,值越大优先级越高,BACKUP一定要低于MASTER
            advert_int 1
            nopreempt            #开启非抢占模式
            authentication {
                auth_type PASS
                auth_pass 1111
            }
            virtual_ipaddress {
                192.168.0.10  # 要生成的VIP地址
            }
        }

        virtual_server 192.168.0.10 3306 {    # 虚拟服务的IP和端口
            delay_loop 6
            protocol TCP

            real_server 127.0.0.1 3306 {         # 真实服务的IP和端口
                weight 1
                notify_down "pkill keepalived"   # 真实服务器端口连不上的时候执行的命令,停止keepalived
                TCP_CHECK {                # 健康检查策略,TCP_CHECK,用tcp协议连接端口
                    connect_port 3306      # 健康检查连接的端口
                    connect_timeout 3      # 连接超时时间
                    nb_get_retry 3         # 重试次数
                    delay_before_retry 3   # 健康检查轮询时间间隔
                }
            }
        }


B机器配置:
# 清空keepalived.conf 中的内容,copy如下内容
vi /etc/keepalived/keepalived.conf
vrrp_instance VI_1 {
            state BACKUP         # 初始状态为BACKUP
            interface ens224     # ip a查看网卡名称,选择当前机器服务IP所在的网卡名称
            virtual_router_id 51 # 虚拟路由ID,同集群中ID必须一样,且同集群唯一
            priority 91         # 优先级,值越大优先级越高,BACKUP一定要低于MASTER
            advert_int 1
            authentication {
                auth_type PASS
                auth_pass 1111
            }
            virtual_ipaddress {
                192.168.0.10  # 要生成的VIP地址
            }
        }

virtual_server 192.168.0.10 3306 {    # 虚拟服务的IP和端口
            delay_loop 6
            protocol TCP

            real_server 127.0.0.1 3306 {         # 真实服务的IP和端口
                weight 1
                notify_down "pkill keepalived"   # 真实服务器端口连不上的时候执行的命令,停止keepalived
                TCP_CHECK {                # 健康检查策略,TCP_CHECK,用tcp协议连接端口
                    connect_port 3306      # 健康检查连接的端口
                    connect_timeout 3      # 连接超时时间
                    nb_get_retry 3         # 重试次数
                    delay_before_retry 3   # 健康检查轮询时间间隔
                }
            }
        }

四、keepalived使用说明:
如果当前VIP所在的A数据库出现故障,VIP会在三秒内转移至B数据库,将由B数据库提供服务,此时A数据库的mysql服务down掉,keepalived服务也会跟着down掉,需要在修复A数据库后,将A机器的keepalived服务重启,VIP将会继续转移至A数据库。
 

你可能感兴趣的:(Linux软件服务相关,mysql,数据库,服务器,linux)