mysql5.6安装、一主多从配置、读写分离

安装mysql5.6

1.首先宿主机是win10系统,安装的VM VirtualBox,新建三个虚拟主机(虚拟主机安装的是centos7),此过程就不再赘述,不清楚的小伙伴可以查看我的一篇“VM VirtualBox安装centos7、设置IP”文章。

2.检查系统中是否已安装 MySQL

rpm -qa | grep mysql

返回空值的话,就说明没有安装 MySQL 。
3.查看已安装的 Mariadb 数据库版本

rpm -qa|grep -i mariadb

4.卸载已安装的 Mariadb 数据库

rpm -qa|grep mariadb|xargs rpm -e --nodeps

5.下载安装包文件

wget http://repo.mysql.com/mysql-community-release-el7-5.noarch.rpm

6.安装mysql-community-release-el7-5.noarch.rpm包

rpm -ivh mysql-community-release-el7-5.noarch.rpm

7.安装mysql。

yum install mysql-server

8.检查mysql是否安装成功

rpm -qa | grep mysql

9.启动mysql服务

systemctl start mysqld.service #启动 mysql
systemctl restart mysqld.service #重启 mysql
systemctl stop mysqld.service #停止 mysql
systemctl enable mysqld.service #设置 mysql 开机启动

mysql常用文件路径:

/etc/my.cnf   这是mysql的主配置文件
/var/lib/mysql   mysql数据库的数据库文件存放位置
/var/logs/mysqld.log  数据库的日志输出存放位置

9.设置密码
mysql5.6 安装完成后,它的 root 用户的密码默认是空的,我们需要及时用 mysql 的 root 用户登录(第一次直接回车,不用输入密码),并修改密码。

mysql -u root
mysql> use mysql;
mysql> update user set password=PASSWORD("这里输入root用户密码") where User='root';
mysql> flush privileges;

10.设置远程主机登录

mysql> GRANT ALL PRIVILEGES ON . TO 'your username'@'%' IDENTIFIED BY 'your password';

执行以下命令,为root 用户添加远程登录的能力。

mysql> GRANT ALL PRIVILEGES ON . TO root@"%" IDENTIFIED BY "123456";

11.如果还不能用数据库工具进行连接,防火墙需要开放对应端口
firewall添加端口

firewall-cmd --zone=public --add-port=3306/tcp --permanent

重启防火墙

systemctl restart firewalld.service

查看所有开放的端口

firewall-cmd --list-ports

连接成功

一主多从配置

整体架构
Master节点配置

主库配置主要包含开启binlong日志,设置server-id
修改/etc/my.cnf。

[mysqld]
#开启binlog日志功能
log_bin=mysql-bin
#设置server-id
server-id=1
sync-binlog=1
#设置忽略的数据库
binlog-ignore-db=information_schema
binlog-ignore-db=performance_schema
binlog-ignore-db=sys
binlog-ignore-db=mysql
#读写都可以
read-only = 0

注解:sync_binlog”:这个参数是对于MySQL系统来说是至关重要的,他不仅影响到Binlog对MySQL所带来的性能损耗,而且还影响到MySQL中数据的完整性。对于“sync_binlog”参数的各种设置的说明如下:
sync_binlog=0,当事务提交之后,MySQL不做fsync之类的磁盘同步指令刷新binlog_cache中的信息到磁盘,而让Filesystem自行决定什么时候来做同步,或者cache满了之后才同步到磁盘。
sync_binlog=n,当每进行n次事务提交之后,MySQL将进行一次fsync之类的磁盘同步指令来将binlog_cache中的数据强制写入磁盘。
在MySQL中系统默认的设置是sync_binlog=0,也就是不做任何强制性的磁盘刷新指令,这时候的性能是最好的,但是风险也是最大的。因为一旦系统Crash,在binlog_cache中的所有binlog信息都会被丢失。而当设置为“1”的时候,是最安全但是性能损耗最大的设置。因为当设置为1的时候,即使系统Crash,也最多丢失binlog_cache中未完成的一个事务,对实际数据没有任何实质性影响。

保存之后重启数据库

systemctl restart mysqld

登录master,并且给从库进行授权操作,授权之后刷新权限。
-- 授权

mysql> grant replication slave on . to 'root(用户名)'@'%' identified by 'root(密码)';
Query OK, 0 rows affected, 1 warning (0.00 sec)
mysql> grant all privileges on . to 'root'@'%' identified by 'root';
Query OK, 0 rows affected, 1 warning (0.00 sec)

-- 刷新权限

mysql> flush privileges;
Query OK, 0 rows affected (0.00 sec)

查看主库Master的状态。(File、Position值后面配置从库要用到)

mysql> SHOW MASTER STATUS;

Slave节点配置

从库开启relay-log中继日志,并且制定server-id。
编辑/etc/my.cnf配置文件

[mysqld]
log_bin=mysql-bin
sync-binlog=1
binlog-ignore-db=information_schema
binlog-ignore-db=mysql
binlog-ignore-db=performance_schema
binlog-ignore-db=sys
#指定server id,slave2机器配置为3
server-id=2
#指定中继日志名称
relay_log=mysql-relay-bin
#开启数据库只读
read_only=1

保存之后重启数据库

systemctl restart mysqld

登录两台slave服务器,创建连接到master服务器进行同步。
注意:执行命令时,参数必须是自己对应的配置,master_log_filemaster_log_pos 为主服务器配置完成后对应的参数

mysql> change master to master_host='192.168.56.101',master_port=3306,master_user='root',master_password='root',master_log_file='mysql-bin.000006',master_log_pos=120;
Query OK, 0 rows affected, 2 warnings (0.01 sec)

启动slave

mysql> start slave;
Query OK, 0 rows affected (0.00 sec)

查看slave状态,主要观察IO线程是否启动。如果 Slave_IO_Running、Slave_SQL_Running不是yes,说明连接主服务器不成功,需要查看原因,可以到日志error.log文件查看问题

mysql> show slave status \G;


对从库进行链接授权:

mysql> grant all privileges on . to 'root'@'%' identified by 'root';
Query OK, 0 rows affected, 1 warning (0.00 sec)
mysql> flush privileges;
Query OK, 0 rows affected (0.01 sec)

小结:以上即为mysql一主多从配置,在实际生产中我们可以设置主服务器进行写操作,从服务器进行读操作,每次主服务器会自动同步数据到所有从服务器。
注意:主服务器数据进行ID自增时,要保证任意从服务器中数据ID不能与主服务器发生冲突,否则会导致从服务器的slave服务挂掉,数据同步失效。此时我们需要删除有冲突的数据,登录从服务器,先停止slave,再重新启动slave

stop slave;
strat slave;

你可能感兴趣的:(mysql5.6安装、一主多从配置、读写分离)