在CentOS上搭建MySQL的主从架构

安装启动MySQL

下载

wget https://cdn.mysql.com/archives/mysql-5.7/mysql-5.7.28-1.el7.x86_64.rpmbundle.tar

解压

tar xvf mysql-5.7.28-1.el7.x86_64.rpm-bundle.tar

安装

  • 要移出CentOS自带的mariadb-libs,不然会提示冲突
    rpm -qa|grep mariadb
    rpm -e mariadb-libs-5.5.41-2.el7_0.x86_64 --nodeps
    

    由于MySQL的server服务依赖了common、libs、client,所以需要按照以下顺序依次安装。 RPM是RedHat公司随Redhat Linux推出的一个软件包管理器,通过它能够更加方便地实现软件的安 装。rpm常用的命令有以下几个:

    -i, --install 安装软件包
    -v, --verbose 可视化,提供更多的详细信息的输出
    -h, --hash 显示安装进度
    -U, --upgrade=<packagefile>+ 升级软件包
    -e, --erase=<package>+ 卸载软件包
    --nodeps 不验证软件包的依赖
    
    组合可得到几个常用命令:
    安装软件:rpm -ivh rpm包名
    升级软件:rpm -Uvh rpm包名
    卸载软件:rpm -e rpm包名
    查看某个包是否被安装 rpm -qa | grep 软件名称
    
  • 下面就利用安装命令来安装mysql:
    rpm -ivh mysql-community-common-5.7.28-1.el7.x86_64.rpm
    rpm -ivh mysql-community-libs-5.7.28-1.el7.x86_64.rpm
    rpm -ivh mysql-community-libs-compat-5.7.28-1.el7.x86_64.rpm
    rpm -ivh mysql-community-client-5.7.28-1.el7.x86_64.rpm
    rpm -ivh mysql-community-server-5.7.28-1.el7.x86_64.rpm
    rpm -ivh mysql-community-devel-5.7.28-1.el7.x86_64.rpm
    

启动

  • 初始化用户
    mysqld --initialize --user=mysql
    
  • 查看初始密码
    cat /var/log/mysqld.log | grep password
    
  • 启动mysql服务
    systemctl start mysqld
    
  • 配置为开机启动
    systemctl enable mysqld
    
  • 接下来登录mysql,修改默认密码。
    mysql -uroot -p
    xxxxxx输入初始密码
    mysql> SET PASSWORD = PASSWORD('新密码');
    Query OK, 0 rows affected, 1 warning (0.00 sec)
    

关闭防火墙

不同的MySQL直接要互相访问,需要关闭Linux的防火墙,否则就要在配置/etc/sysconfig/iptables中增加规则。配置防火墙不是本次作业的重点,所以四台服务器均关闭防火墙

systemctl stop firewalld

MySQL主从配置

Master节点

  • 使用vi /etc/my.cnf命令修改Master配置文件
    #bin_log配置
    log_bin=mysql-bin
    server-id=1
    sync-binlog=1
    binlog-ignore-db=information_schema
    binlog-ignore-db=mysql
    binlog-ignore-db=performance_schema
    binlog-ignore-db=sys
    #relay_log配置
    relay_log=mysql-relay-bin
    log_slave_updates=1
    relay_log_purge=0
    
  • 重启服务
    systemctl restart mysqld
    
  • 主库给从库授权
  • 登录MySQL,在MySQL命令行执行如下命令:
    mysql> grant replication slave on *.* to root@'%' identified by '密码';
    mysql> grant all privileges on *.* to root@'%' identified by '密码';
    mysql> flush privileges;
    //查看主库状态信息,例如master_log_file='mysql-bin.000007',master_log_pos=154
    mysql> show master status;
    

Slave节点

  • 修改Slave的MySQL配置文件my.cnf,两台Slave的server-id分别设置为2和3

    #bin_log配置
    log_bin=mysql-bin
    #服务器ID,从库1是2,从库2是3
    server-id=2
    sync-binlog=1
    binlog-ignore-db=information_schema
    binlog-ignore-db=mysql
    binlog-ignore-db=performance_schema
    binlog-ignore-db=sys
    #relay_log配置
    relay_log=mysql-relay-bin
    log_slave_updates=1
    relay_log_purge=0
    read_only=1
    
  • 重启服务

    systemctl restart mysqld
    
  • 开启同步

    登录MySQL,在Slave节点的MySQL命令行执行同步操作,例如下面命令(注意参数与上面show master status操作显示的参数一致):

    change master to master_host='192.168.xx.xxx',master_port=3306,master_user='root',
    master_password ='123456',master_log_file='mysql-bin.000007',master_log_pos=154;
    #开启同步
    start slave; 
    

猜你喜欢

转载自blog.csdn.net/u013795102/article/details/116782058
今日推荐