zoukankan      html  css  js  c++  java
  • 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.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 ~]# wget https://dev.mysql.com/get/Downloads/MySQL-5.7/mysql-5.7.18-linux-glibc2.5-x86_64.tar.gz

    [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,也可执行建立

    1master上开启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%';

    2master的数据库中建立备份账号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 statusG #

    查看主服务器上当前的二进制日志名和偏移量值这里的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', #masterip

    -> 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

    图中2yes 代表设置成功

    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;

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

  • 相关阅读:
    [置顶] NO.4 使用预处理器进行调试
    VC用OLE方式读写Excel
    Eclipse 4.2 + Tomcat 7.x + JDK 7 搭建Java Web开发环境
    (step4.3.1) hdu 1010(Tempter of the Bone——DFS)
    linked-list-random-node
    insert-delete-getrandom-o1-duplicates-allowed
    C++中对Mysql的操作函数可以参考以下blog中的内容
    insert-delete-getrandom-o1
    kth-smallest-element-in-a-sorted-matrix
    combination-sum-iv
  • 原文地址:https://www.cnblogs.com/imweihao/p/7301537.html
Copyright © 2011-2022 走看看