安装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_file 和 master_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;