MySQL 5.7.18的安装与主从复制

IP

计算机名

角色

192.168.1.222

001

master

192.168.1.233

002

slave

CentOS 6.9安装mysql5.7.18#这里只展示一台的安装过程,另一台一样操作

下载地址:https://dev.mysql.com/get/Downloads/MySQL-5.7/mysql-5.7.18-linux-glibc2.5-x86_64.tar.gz

1、下载,解压,并创建软链接

[root@001 ~]# tar xf mysql-5.7.18-linux-glibc2.5-x86_64.tar.gz -C /usr/local/

[root@001 ~]# cd /usr/local/

[root@001 local]# ln -sv mysql-5.7.18-linux-glibc2.5-x86_64/ mysql

2、新建mysql用户组和mysql用户

[root@001 local]# groupadd mysql

[root@001 local]# useradd -g mysql -r -s /sbin/nologin -M -d /data/mysqldata mysql

3、新建数据目录并赋予相关属组及权限

[root@001 local]# chown -R mysql:mysql /usr/local/mysql

[root@001 local]# mkdir -p /data/mysqldata

[root@001 local]# chmod -R 770 /data/mysqldata

[root@001 local]# chown -R mysql:mysql /data/mysqldata

4、初始化mysqld

[root@001 local]# cd /usr/local/mysql

[root@001 mysql]# ./bin/mysqld --user=mysql --basedir=/usr/local/mysql --datadir=/data/mysqldata --initialize

初始化完成后需记录下初始化密码

5、编辑配置文件及将mysql的服务脚本放到系统服务中,并配置环境变量让系统可以直接使用mysql的相关命令

[root@001 mysql]# cp support-files/mysql.server /etc/init.d/mysqld

[root@001 mysql]# ldconfig

[root@001 mysql]# echo "PATH=$PATH:/usr/local/mysql/bin" > /etc/profile.d/mysql.sh

[root@001 mysql]# source /etc/profile.d/mysql.sh

[root@001 mysql]# chkconfig mysqld on

[root@001 mysql]# vim /etc/my.cnf

[mysqld]

basedir=/usr/local/mysql #mysql路径

datadir=/data/mysqldata #mysql数据目录

socket=/tmp/mysql.sock

user=mysql

server_id=1 #MySQLid后面2个从服务器需设置不同

port=3306

[root@001 mysql]# service mysqld start #启动mysql

Starting MySQL.Logging to '/data/mysqldata/001.err'.

. SUCCESS! #启动成功

6、修改密码

[root@001 mysql]# mysql -uroot -pdSrp%=Gdw4y: #这里的密码上刚才记录下来的

mysql> set password='123456';

mysql> FLUSH PRIVILEGES;

7、设置mysql远程可访问(前提是防火墙必须关闭,chkconfig iptables off:设置自动启动为关闭,service iptables sto:关闭防火墙)

[root@001 mysql]# service iptables stop

[root@001 mysql]# chkconfig iptables off

先登录到mysql

mysql> use mysql;

mysql> update user set host = '%' where user = 'root'; #按实际情况设置

mysql> flush privileges;

----以上是上台测试机安装MySQL5.7.18的全部步骤----

----下面开始配置MySQL5.7.18的主从复制----

MySQL主从复制

IP

计算机名

角色

192.168.1.222

001

master

192.168.1.233

002

slave

#这里先导入测试数据库用于同步详见:http://www.cnblogs.com/imweihao/p/7286926.html,也可执行建立

1、master上开启binlog日志,配置如下

一般mysql配置文件在目录/etc下,叫my.cnf (如果找不到的话也有可能在这些目录下:/etc/my.cnf,/etc/mysql/my.cnf,/usr/local/mysql/etc/my.cnf,~/.my.cnf)

[mysqld]

basedir=/usr/local/mysql

datadir=/data/mysqldata

socket=/tmp/mysql.sock

user=mysql

server-id=1

port=3306

server-id=1 #服务器id (主从必须不一样)

log-bin=mysql-bin #打开日志(主机需要打开),这个mysql-bin也可以自定义,这里也可以加上路径

#作为主机的配置

binlog-do-db=employees #要给从机同步的库

#binlog-do-db=

binlog-ignore-db=mysql #不给从机同步的库(多个写多行)

binlog-ignore-db=information_schema

binlog-ignore-db=performance_schema

binlog-ignore-db=sys

expire_logs_days=7 #自动清理7天前的log文件,可根据需要修改

[root@001 employees_db]# service mysqld restart #重启数据库

测试log_bin是否成功开启

mysql> show variables like '%log_bin%';

2、master的数据库中建立备份账号:backup为用户名,%表示任何远程地址,如下表示密码为1234的任何远程地址的backup都可以连接master主机

mysql> grant replication slave on *.* to 'backup'@'%' identified by '123456';

mysql> use mysql

mysql> select user,authentication_string,host from user;

3、拷贝数据

重启MySQL服务并设置读取锁定,读取锁定的意思是只能读取,不能更新,以便获得一个一致性的快照

mysql> show master status\G #

查看主服务器上当前的二进制日志名和偏移量值这里的file和position要和从上的一致

导出master(192.168.1.222)种的数据,然后导入slave中

master:

[root@001 employees_db]# mysqldump -uroot -p123456 -hlocalhost employees > /opt/employees.bak

[root@001 employees_db]# yum install openssh-clients -y #(注:slave也需要安装)

slave:

[root@001 employees_db]# yum install openssh-clients -y

[root@001 ~]# scp /opt/employees.bak root@192.168.1.233:/opt/

root@192.168.1.233's password: #输入密码

employees.bak 100%

4、配置slave(192.168.1.233)

[root@002 ~]# vim /etc/my.cnf

[mysqld]

basedir=/usr/local/mysql #mysql路径

datadir=/data/mysqldata #mysql数据目录

socket=/tmp/mysql.sock

user=mysql

server_id=2 #MySQLid后面2个从服务器需设置不同

port=3306

#加上以下参数可以避免更新不及时,SLAVE 重启后导致的主从复制出错。

read_only = 1

master_info_repository=TABLE

relay_log_info_repository=TABLE

#relay_log_recovery=1#从机禁止写

#super_read_only=1#从机禁止写

然后导入到mysql数据库中,slave上的employees数据库不存在则先创建,然后再导入

mysql> create database employees;

[root@002 ~]# mysql -uroot -p123456 -hlocalhost employees < /opt/employees.bak

[root@002 ~]# service mysqld restart

登录slave数据库,并做如下设置

[root@002 ~]# mysql -uroot -p123456

mysql> stop slave;

mysql> change master to

-> master_host='192.168.1.222', #master的ip

-> master_user='backup', #备份用户名

-> master_password='123456', #密码

-> master_log_file='mysql-bin.000002', #上面截图,且要与master的参数一致

-> master_log_pos=154;#上面截图,且要与master的参数一致

mysql> start slave;

查看slave从机的状态

mysql> show slave status \G

图中2个yes代表设置成功

5、关闭掉主数据库的读取锁定,并测试

mysql> unlock tables;

在marster中创建一个新表再查看slave中是否有数据

master:

mysql> use employees;

mysql> create table test001(id int auto_increment primary key,name varchar(20) not null);

mysql> insert into test001 values(null,'will');

mysql> insert into test001 values(null,'jim');

mysql> insert into test001 values(null,'tom');

slave:

mysql> use employees;

mysql> show tables;

mysql> select * from test001;

测试2:重启关闭从数据库,主删除test001表,然后主从数据库都重启看是否正常

mysql> drop table test001;

以上实验证明主从同步成功!!!

mysql5.7主从复制_MySQL 5.7.18的安装及主从复制(主从同步)相关推荐

  1. mysql 5.7.19主从复制_MySQL 5.7.18的安装及主从复制(主从同步)

    MySQL 5.7.18的安装与主从复制 IP 计算机名 角色 192.168.1.222 001 master 192.168.1.233 002 slave CentOS 6.9安装mysql5. ...

  2. mysql拷贝文件安装_Mysql5.7.18的安装与主从复制图文详解

    CentOS6.7安装mysql5.7.18 1.  解压到/usr/local目录 # tar -zxvf mysql-5.7.18-linux-glibc2.5-i686.tar.gz -C /u ...

  3. mysql msi 是离线安装吗_mysql 5.7.18 MSI安装图文教程

    本文为大家分享了mysql 5.7.18 MSI安装教程,供大家参考,具体内容如下 1.下载:官网地址 可以看到note32位和64位下载是一样的 2.双击下载的文件 3.安装页面 4选择安装类型(选 ...

  4. CentOS使用docker部署mysql5.7、可使用navicat连接mysql服务,以及主从同步配置

    查找待拉取的镜像 mysql镜像地址:https://hub.docker.com/_/mysql?tab=tags 我使用的是5.3.37的版本:docker pull mysql:5.7.37 d ...

  5. mysql5.7.18的安装与主从复制

    CentOS6.7安装mysql5.7.18 1.  解压到/usr/local目录 # tar -zxvf mysql-5.7.18-linux-glibc2.5-i686.tar.gz -C /u ...

  6. MySQL 5.7.18的安装与主从复制(转自:https://www.baidu.com/home/news/data/newspage?nid=9485770887287731252n_typ)

    CentOS6.7安装mysql5.7.18 1. 解压到/usr/local目录 # tar -zxvf mysql-5.7.18-linux-glibc2.5-i686.tar.gz -C /us ...

  7. MySQL 5.7.18的安装与主从复制

    CentOS6.7安装mysql5.7.18 1.  解压到/usr/local目录 # tar -zxvf mysql-5.7.18-linux-glibc2.5-i686.tar.gz -C /u ...

  8. mysql 5.7 多线程主从复制_Mysql 5.7从节点配置多线程主从复制的方法详解

    前言 Mysql 采用多线程进行复制是从 Mysql 5.6 开始支持的内容,但是 5.6 版本下有缺陷,虽然支持多线程,但是每个数据库只能一个线程,也就是说如果我们只有一个数据库,则主从复制时也只有 ...

  9. mysql 取消主从复制_MySQL:第一次看到有人把MySQL主从复制讲解的这么清楚

    一.基本原理 MySQL复制过程分成三步: 1).master将改变记录到二进制日志(binary log).这些记录过程叫做二进制日志事件,binary log events: 2).slave将m ...

  10. mysql5.2 软件园_MySQL Server V5.5 官方安装版

    MySQL Server是一个多线程的,结构化查询语言SQL数据库服务器,此MySQL数据库的执行性能非常高,运行速度非常快,拥有最全面的高级功能.管理工具和技术支持,非常容易使用,是一个非常捧的数据 ...

最新文章

  1. [Android] 环境配置之Android Studio开发NDK
  2. 惊了,电子元件还能这样玩?这是电子器件的艺术魅力
  3. (软件工程复习核心重点)第二章可行性研究-第三节:数据流图
  4. java:去除字符串中空格 、 oracle (+) 、 mysql中数值运算符和函数
  5. 屌丝就爱尝鲜头——java8再判断
  6. 推荐21个顶级的Vue UI库!
  7. WSL1安装GUI界面
  8. 半监督学习入门基础(二):最基础的3个概念
  9. 打蚊子表情包_拍蚊子表情包 - 拍蚊子微信表情包 - 拍蚊子QQ表情包 - 发表情 fabiaoqing.com...
  10. 12种常见贴片焊接工具
  11. Python与Julia结合使用的个人经验
  12. 自适应中值滤波器python实现
  13. iOS静态库SDK制作(包含支付宝支付、微信支付或其它第三方静态库)
  14. Js 的防抖与节流代码分析
  15. 学院后勤报修系统php,学校后勤报修系统功能介绍
  16. 自然语言处理之机器智能
  17. libnet的使用详解
  18. Gnuradio+uhd驱动软件安装流程
  19. 企业项目实战k8s篇(十三)k8s容器资源限制
  20. docker嵌入式开发(六)安装nextcloud云盘

热门文章

  1. Linux文件传输与mysql数据库安装
  2. 跟着辛星认识一下PHP的自己主动载入
  3. 利用JDBC开发图书管理系统
  4. tortoiseHg查看后一个版本和parent版本的不同
  5. Java把日期转为周几
  6. mysql 四种隔离级别
  7. Microsoft caffe(caffe-windows) cifar实例编译之model的使用
  8. 学习OpenGL ES之法线贴图
  9. Python 列表深浅复制详解
  10. WPF Visifire 图表控件