yeskery

MySQL 5.7.21 安装和主从同步

碎碎念

惯例碎碎念。

很久之前就做过mysql的部分应用架构,包括主从复制和集群等,一直没有形成博客记录下来,虽然网上也有很多的相关资料,但是出于加深记忆,还是把自己的操作步骤和截图一步步记录下来,回头忘了也可以回顾,当然,也希望有小伙伴能得到帮助。

环境

一台装有vsphere6.5的宿主机,和宿主机上的centos虚拟机若干。

  1. vsphere 6.5
  2. centos 7
  3. mysql 5.7
  4. navicat 8
  5. windows 10

安装mysql

yum 方式安装

  1. # 进入文件夹
  2. cd /usr/local
  3. # 创建你自己的文件夹
  4. mkdir zoro zoro/setup
  5. # 进入创建的文件夹
  6. cd zoro/setup
  7. # 下载官方yum源包
  8. wget https://repo.mysql.com//mysql57-community-release-el7-11.noarch.rpm
  9. # 赋予执行权限
  10. chmod +x mysql57-community-release-el7-11.noarch.rpm
  11. # 本地安装,一路Y就行了
  12. yum localinstall mysql57-community-release-el7-11.noarch.rpm
  13. # 启动
  14. systemctl start mysqld
  15. # 获取临时密码
  16. grep 'temporary password' /var/log/mysqld.log
  17. # 登录mysql
  18. mysql -uroot -pYourPwd
  19. # 修改密码 OR 配置等,你想干嘛就干嘛

MySQL_Master_Slave_Step_1

MySQL_Master_Slave_Step_2

MySQL_Master_Slave_Step_3

MySQL_Master_Slave_Step_4

MySQL_Master_Slave_Step_5

MySQL_Master_Slave_Step_6

MySQL_Master_Slave_Step_7

二进制安装

  1. # 进入文件夹
  2. cd /usr/local
  3. # 创建你自己的文件夹
  4. mkdir zoro zoro/setup
  5. # 进入创建的文件夹
  6. cd zoro/setup
  7. # 下载二级制包,地址二选一
  8. # 官网镜像,跟乌龟似的
  9. wget https://cdn.mysql.com//Downloads/MySQL-5.7/mysql-5.7.21-linux-glibc2.12-x86_64.tar.gz
  10. # 国内镜像,速度杠杠的
  11. wget http://mirrors.ustc.edu.cn/mysql-ftp/Downloads/MySQL-5.7/mysql-5.7.21-linux-glibc2.12-x86_64.tar.gz
  12. # 解压缩
  13. tar zxvf mysql-5.7.21-linux-glibc2.12-x86_64.tar.gz
  14. # 移动并重命名到指定地方,需要先创建目录
  15. mkdir /usr/local/server
  16. mv mysql-5.7.21-linux-glibc2.12-x86_64 /usr/local/server/mysql
  17. # 进入mysql 目录
  18. cd /usr/local/server/mysql
  19. # 创建data目录
  20. mkdir /data /data/db /data/db/mysql
  21. # 检查和创建用户
  22. cat /etc/group | grep mysql
  23. # 如过查无结果,则创建mysql用户
  24. groupadd mysql
  25. useradd -r -g mysql mysql
  26. #科普1:-g, --gid GROUP 新账户主组的名称或 ID
  27. #科普2:-r, --system 创建一个系统账户,不可用于登录
  28. # 赋权
  29. chown -R mysql:mysql /data/db/mysql
  30. chmod 750 /data/db/mysql
  31. # 执行安装
  32. ./bin/mysqld --initialize --user=mysql --basedir=/usr/local/server/mysql --datadir=/data/db/mysql
  33. # 记录屏幕中的临时密码
  34. A temporary password is generated for root@localhost: >wmujowe!68H
  35. # 如果basedir和datadir修改过,需要先修改./support-files/mysql.server
  36. vim ./support-files/mysql.server
  37. #填入
  38. basedir=/usr/local/server/mysql
  39. datadir=/data/db/mysql
  40. # 复制服务脚本
  41. cp -a ./support-files/mysql.server /etc/init.d/mysqld
  42. # 编辑配置文件,将data目录等参数修正
  43. # 1、如果以下两个目录不在上面赋权的范围内,也要重新赋权,否则无法启动
  44. log-error=/var/log/mysql/mariadb.log
  45. pid-file=/var/run/mysql/mariadb.pid
  46. chown -R mysql:mysql /var/log/mysql
  47. # 2、配置文件加入[mysql]节点,用以客户端连接
  48. [mysql]
  49. socket=/data/db/mysql/mysql.sock
  50. # 加入环境变量
  51. export PATH=$PATH:/usr/local/server/mysql/bin
  52. # 启动mysql
  53. service mysqld start
  54. # 接下来的步骤就和yum方式类似了,不再赘述
  55. mysql -uroot -pYouPwd
  56. ...

MySQL_Master_Slave_Step_8

MySQL_Master_Slave_Step_9

其他说明

除了上述两种方式外,还有源码安装等方式,如有兴趣,请自行研究。

yum方式安装相对来说比较省事,但是由于下载镜像在国外,一般速度较慢,如果不能接受的话建议采用其他方式。

二进制安装稍微繁琐一点,建议有Linux经验的小伙伴采用。

Tips

修改密码

提供关于修改密码的命令

  1. # 登录
  2. mysql -uroot -pYourPwd
  3. # 第一种方式
  4. >set password=password("YourNewPwd");
  5. # 第二种方式
  6. >use mysql;
  7. >update user set authentication_string=password("YourNewPwd") where User='root';

移动data目录

默认的mysqldata目录在于 /var/lib/mysql,如果需要移动目录,可以参考下列操作

  1. # 关闭mysql
  2. systemctl stop mysqld
  3. # 创建你自己的目录
  4. mkdir /data/db
  5. # 移动mysql文件夹
  6. mv /var/lib/mysql /data/db
  7. # 更改权限
  8. chown -R mysql:mysql /data/db/mysql
  9. # 启动mysql
  10. sysctemctl start mysqld
  11. # 如果遇到启动问题,一般先检查配置文件是否有错
  12. # 如果确认配置文件没错,还启动不了,可以尝试下面的设置
  13. vim /etc/selinux/config
  14. # 设置 SELINUX=disabled
  15. # 保存重启
  16. reboot
  17. # 再次尝试启动mysql
  18. sysctemctl start mysqld

Tips:
关于selinux这里不做赘述,有兴趣的可以去查阅资料了解

创建用户和赋权

提供关于创建用户和赋权的基础命令,如需了解详细内容,请参考官网

  1. Create user user’@’host identified by YourPwd’;
  2. # 赋予权限(原则上是最小权限赋予,此处赋予db.tables的全部权限)
  3. Grant all on db.tables to user;
  4. flush privileges;

防火墙开放端口

如果你开启了防火墙,需要开放默认的3306端口,否则外网无法访问

  1. # 查看防火墙状态
  2. systemctl status firewalld
  3. # 如果防火墙开启,需要开放3306端口
  4. firewall-cmd --zone=public --add-port=3306/tcp --permanent
  5. # 重启防火墙
  6. systemctl restart firewalld

主从配置

前提条件,分别在两台服务器上安装msyql服务

  1. IP 192.168.1.246centOS7 + mysql master
  2. IP : 192.168.1.249centOS7 + mysql slave

master配置

这里不区分库,针对所有的库都做主从复制,如果需要特定库做主从复制的,请翻阅其他说明

vim /etc/my.cnf

  1. log-bin=mysql-bin
  2. server-id=246
  3. log_bin_trust_function_creators=1

重启mysql,并登陆mysql进行操作

  1. systemctl restart mysqld
  2. mysql -uroot -pYourPwd
  3. #创建同步账号,赋予权限,这里进行演示,不做权限限制和ip限制,请知悉
  4. mysql>GRANT FILE ON *.* TO 'slave'@'%' IDENTIFIED BY 'YourSlavePwd';
  5. mysql>GRANT replication slave on *.* to slave’@’%’ identified by 'YourSlavePwd'
  6. mysql>flush privileges;
  7. #查看主服务器状态,并记录下状态
  8. mysql> show master status;

slave配置

vim /etc/my.cnf

  1. read_only=1
  2. log-bin=mysql-bin
  3. server-id=249
  4. log_bin_trust_function_creators=1

重启mysql,并登陆mysql进行操作

  1. systemctl restart mysqld
  2. mysql -uroot -pYourPwd
  3. # 配置master,并开启同步
  4. mysql> change master to master_host='192.168.1.246',master_user='slave',master_password='YourSlavePwd', master_log_file='mysql-bin.000033',master_log_pos=57883;
  5. # 开启同步
  6. mysql> start slave;
  7. # 查看同步状态
  8. mysql> show slave status\G;
  9. # 如果出现以下两个Yes,证明同步成功,如果出现问题,请翻阅`其他`
  10. Slave_IO_Running: Yes
  11. Slave_SQL_Running: Yes

验证

  1. 用Navicat分别连接主库和从库

  2. 在主库对某些记录进行修改

  3. 查看从库是否同步了主库的修改

其他

这里分成两部分,一部分针对主从复制中,只要求同步部分库的配置,另一部分记录主从不同步的解决方法。

部分同步

需要修改 my.cnf 的配置文件,包括 replicate-ignore-dbreplicate-ignore-db 以及 binlog-do-dbbinlog-ignore-db 等参数配合。

具体配置说明请参考这里

主从不同步解决

  1. 忽略错误后,继续同步。(该方法适用于主从库数据相差不大,或者要求数据可以不完全统一的情况,数据要求不严格的情况。)
  1. 1)、停止同步
  2. mysql>stop slave;
  3. 2)、设置参数
  4. mysql>set global sql_slave_skip_counter =1;
  5. 3)、启动同步并查看
  6. start slave;
  7. mysql> show slave status\G;
  8. Slave_IO_Running: Yes
  9. Slave_SQL_Running: Yes
  1. 重新做主从,完全同步。(该方法适用于主从库数据相差较大,或者要求数据完全统一的情况。)
  1. 1)、进入主库,进行锁表,防止数据写入。注意:该处是锁定为只读状态,语句不区分大小写
  2. mysql> flush tables with read lock;
  3. 2)、进行数据备份并解锁
  4. mysqldump -uroot -pYouPwd YourDB > bak.sql
  5. mysql> UNLOCK TABLES;
  6. 3)、查看master 状态并记录
  7. mysql> show master status;
  8. 4)、把mysql备份文件传到从库机器,进行数据恢复
  9. 5)、停止从库的状态
  10. mysql> stop slave;
  11. 6)、从库执行mysql命令,导入数据备份
  12. 7)、设置从库同步,具体参数请根据master status填写
  13. change master to master_host = '192.168.1.246', master_user = 'slave', master_port=3306, master_password='YourSalvePwd', master_log_file = 'mysqld-bin.000035', master_log_pos=120;
  14. 8)、重新开启从同步
  15. mysql> start slave;
  16. 9)、查看同步状态
  17. mysql> show slave status\G;
  18. Slave_IO_Running: Yes
  19. Slave_SQL_Running: Yes

参考

Mysql官方文档 - yum安装
Mysql官方文档 - bin安装

本文转载自:http://www.imooc.com/article/253030

评论

发表评论 点击刷新验证码

提示

该功能暂未开放