zoukankan      html  css  js  c++  java
  • mysql+centos7+主从复制

    MYSQL(mariadb)

    MariaDB数据库管理系统是MySQL的一个分支,主要由开源社区在维护,采用GPL授权许可。
    开发这个分支的原因之一是:甲骨文公司收购了MySQL后,有将MySQL闭源的潜在风险,因此社区采用分支的方式来避开这个风险。
    MariaDB的目的是完全兼容MySQL,包括API和命令行,使之能轻松成为MySQL的代替品。

    方法1:yum安装mariadb

    yum install mariadb-server mariadb 

    相关命令

     
    mariadb数据库的相关命令是:
    
    systemctl start mariadb  #启动MariaDB
    
    systemctl stop mariadb  #停止MariaDB
    
    systemctl restart mariadb  #重启MariaDB
    
    systemctl enable mariadb  #设置开机启动
     

    启动后正常使用mysql

    systemctl start mariadb
    
    #进入mysql
    mysql -uroot -p

    方法2:官网下载mysql-server包(rpm)

    # wget http://dev.mysql.com/get/mysql-community-release-el7-5.noarch.rpm
    # rpm -ivh mysql-community-release-el7-5.noarch.rpm
    # yum install mysql-community-server

    配置mysql

    1.中文编码设置

     
    编辑mysql配置文件/etc/my.cnf
    [mysqld]
    character-set-server=utf8
    datadir=/var/lib/mysql
    socket=/var/lib/mysql/mysql.sock
    collation-server=utf8_general_ci
    
    security risks
    symbolic-links=0
    log-error=/var/log/mysqld.log
    pid-file=/var/run/mysqld/mysqld.pid
    
    [client]
    default-character-set=utf8
    [mysql]
    default-character-set=utf8
     

    2.授权配置

     
    远程连接设置哦设置所有库,所有表的所有权限,赋值权限给所有ip地址的root用户
    mysql > grant all privileges on *.* to root@'%' identified by 'password';
    #创建用户
    mysql > create user 'username'@'%' identified by 'password';
    #刷新权限
    flush privileges;
     

    MYSQL主从复制

    MySQL数据库的主从复制方案,是其自带的功能,并且主从复制并不是复制磁盘上的数据库文件,而是通过binlog日志复制到需要同步的从服务器上。

    MySQL数据库支持单向、双向、链式级联,等不同业务场景的复制。在复制的过程中,一台服务器充当主服务器(Master),接收来自用户的内容更新,而一个或多个其他的服务器充当从服务器(slave),接收来自Master上binlog文件的日志内容,解析出SQL,重新更新到Slave,使得主从服务器数据达到一致。

    主从复制的逻辑有以下几种

    一主一从,单向主从同步模式,只能在Master端写入数据

    一主多从

    双主主复制逻辑架构,此架构可以在Master1或Master2进行数据写入,或者两端同事写入(特殊设置)

    在生产环境中,MySQL主从复制都是异步的复制方式,即不是严格的实时复制,但是给用户的体验都是实时的。
    MySQL主从复制集群功能使得MySQL数据库支持大规模高并发读写成为可能,且有效的保护了服务器宕机的数据备份。

    应用场景

    利用复制功能当Master服务器出现问题时,我们可以人工的切换到从服务器继续提供服务,此时服务器的数据和宕机时的数据几乎完全一致。
    复制功能也可用作数据备份,但是如果人为的执行drop,delete等语句删除,那么从库的备份功能也就失效了.

    主从机制实现原理

    (1) master将改变记录到二进制日志(binary log)中(这些记录叫做二进制日志事件,binary log events); 
    (2) slave将master的binary log events拷贝到它的中继日志(relay log); 
    (3) slave重做中继日志中的事件,将改变反映它自己的数据。

    master主库配置

     
    #查看数据库状态
    systemctl status mariadb
    #停mariadb
    systemctl stop mariadb

    #修改配置文件
    vim /etc/my.cnf
    #修改内容
    #解释:server-id服务的唯一标识(主从之间都必须不同);log-bin启动二进制日志名称为mysql-bin

      [mysqld]
      server-id=1
      log-bin=mysql-bin

    #重启mariadb
    systemctl start mariadb
     

    master主库添加从库账号

     
    1.新建用于主从同步的用户chaoge,允许登录的从库是'192.168.178.130'
    create user 'chaoge'@'192.168.178.130' identified by 'redhat';
    
    2.#题外话:如果提示密码太简单不复合策略加在前面加这句
    mysql> set global validate_password_policy=0;
    
    3.给从库账号授权,说明给chaoge从库复制的权限,在192.168.178.130机器上复制
    grant replication slave on *.* to 'chaoge'@'192.168.178.130';
    #检查主库创建的复制账号
    select user,host from mysql.user;
    #检查授权账号的权限
    show grants for chaoge@'192.168.178.130';

    实现对主数据库锁表只读,防止数据写入,数据复制失败
    flush table with read lock;

    4.检查主库的状态

    MariaDB [(none)]> show master status
    -> ;
    +------------------+----------+--------------+------------------+
    | File | Position | Binlog_Do_DB | Binlog_Ignore_DB |
    +------------------+----------+--------------+------------------+
    | mysql-bin.000001 | 575 | | |
    +------------------+----------+--------------+------------------+
    1 row in set (0.00 sec)

    File是二进制日志文件名,Position 是日志开始的位置。后面从库会用到 后面从库会用到 后面从库会用到!!!!!!

    5.锁表后,一定要单独再打开一个SSH窗口,导出数据库的所有数据,

    [root@oldboy_python ~ 19:32:45]#mysqldump -uroot -p --all-databases > /data/all.sql 

    6.确保数据导出后,没有数据插入,完毕再查看主库状态

    show master status;

    7.导出数据完毕后,解锁主库,恢复可写;

    unlock tables;

    8.将备份导出的数据scp至Slave数据库

    scp /data/all.sql root@192.168.178.130:/data/

     

    slave从库配置

    1.设置server-id值并关闭binlog功能参数
    数据库的server-id在主从复制体系内是唯一的,Slave的server-id要与主库和其他从库不同,并且注释掉Slave的binlog参数。
    2.因此修改Slave的/etc/my.cnf,写入
    [mysqld]
    server-id=3
    3.重启数据库
    systemctl restart mariadb
    4.检查Slava从数据库的各项参数
    show variables like 'log_bin';
    show variables like 'server_id';
    5.恢复主库Master的数据导入到Slave库
    导入数据(注意sql文件的路径)
    mysql>source /data/all.sql;
    方法二:
    #mysql -uroot -p < abc.sql
    6.配置复制的参数,Slave从库连接Master主库的配置
    mysql > change master to master_host='192.168.178.129',
    master_user='chaoge',
    master_password='redhat',
    master_log_file='mysql-bin.000001',
    master_log_pos=575;
    7.启动从库的同步开关,测试主从复制的情况
    start slave;
    8.查看复制状态
    show slave statusG;

     检查主从复制是否成功的关键在于

     
     
     
  • 相关阅读:
    在WCF中使用Flag Enumerations
    WCF开发教程资源收集
    [转]WCF 4 安全性和 WIF 简介
    Asp.Net Web API 2 官网菜鸟学习系列导航[持续更新中]
    Asp.Net Web API 2第十八课——Working with Entity Relations in OData
    Asp.Net Web API 2第十七课——Creating an OData Endpoint in ASP.NET Web API 2(OData终结点)
    Asp.Net Web API 2第十六课——Parameter Binding in ASP.NET Web API(参数绑定)
    Asp.Net Web API 2第十五课——Model Validation(模型验证)
    函数 生成器 生成器表达式
    函数的进阶
  • 原文地址:https://www.cnblogs.com/yimiflh/p/9551349.html
Copyright © 2011-2022 走看看