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

本文详细介绍了在CentOS7环境下如何安装MySQL5.6,包括检查与卸载旧数据库、安装步骤、设置密码、开启远程访问,以及详细的一主多从配置过程,包括主库与从库的配置、权限设置和数据同步注意事项。
摘要由CSDN通过智能技术生成

安装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.下载安装包文件

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;

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值