zoukankan      html  css  js  c++  java
  • mysql 主从同步 mysql代理服务器

    搭建mysql主从同步(实现数据自动备份)
    实例:
    把主机192.168.4.100的数据库配置为主机192.168.4.99的从数据库

    主数据库服务器配置
    修改配置文件:
    [root@mysql ~]# vim /etc/my.cnf
    [mysqld]
    log-bin=hydra80(启用binlog日志,从服务器主机位)
    server_id=80(从服务器主机位)
    [root@mysql ~]# /etc/init.d/mysql restart
    用户授权:
    mysql> grant replication slave on *.* to hydra@"192.168.4.100" identified by "Anonymous";

    从数据库服务器配置(从库上一定要有主库上的库)
    测试主数据库授权:
    [root@stu ~]# mysql -h192.168.4.99 -uhydra -pAnonymous
    修改配置文件:
    [root@stu ~]# vim /etc/my.cnf
    [mysqld]
    log-bin=mysql99(主服务器主机位)
    server_id=99(主服务器主机位)
    [root@stu ~]# /etc/init.d/mysqld restart

    把192.168.4.100配置为192.168.4.99的从数据库服务器
    mysql> show slave status;(查看本机是不是从服务器)
    mysql> show master status;(查看数据库的binlog日志文件名)
    配置从数据库服务器格式:
    change master to master_host="主数据库ip",master_user"授权用户",master_password="授权密码",master_log_file="主数据库的binlog日志名",master_log_pos=Position记录的数字
    测试:
    mysql>change master to master_host="192.168.4.99",master_user="hydra",master_password="Anonymous",master_log_file="hydra80.000001",master_log_pos=120;
    mysql> start slave;
    Slave_IO_Running: Yes(两个yes才可以同步数据)
    Slave_SQL_Running: Yes

    在主数据库创建数据测试
    mysql> create database hydra01;(主数据库)
    查看从数据库是否有数据库:
    mysql> show databases;(从数据库)
    hydra01

    ————————————————————————————————————————————————————————————————————————————————————

    主从同步过程
    Slave_IO_Running: io线程负责把主数据库服务器binlog日志里的sql命令同步到本机中继日志里
    IO出错的原因:iptables,selinux grat 指定的binlog日志信息错误
    报错信息Last_IO_Error:查看报错信息,排错

    Slave_SQL_Running: sql线程负责执行本机中继日志里的sql命令,把数据写入本机的库里
    SQL线程出错的原因:执行sql命令时,使用的库,表在本机不存在
    报错信息Last_SQL_Error:查看报错信息,排错

    数据库事务日志
    [root@stu ~]# ls /var/lib/mysql/
    stu-relay-bin.000001(中继日志)
    stu-relay-bin.index(中继日志的索引文件)
    relay-log.info(中继日志信息)
    master.info(连接主数据库的信息)

    让从库暂时不同步主数据库服务器的数据:
    mysql> stop slave;

    把从数据库服务器恢复为一台独立的数据库服务器:
    [root@stu ~]# rm -rf /var/lib/mysql/master.info relay-log.info stu-relay-bin.*
    [root@stu ~]# /etc/init.d/mysql restart


    主从配置的常用选项:
    [root@mysql ~]# vim /etc/my.cnf(在主数据库上配置,限制的是所有的从数据库)
    binglog-do-db=库名(允许从数据库同步的库)
    binlog-ignore-db=库名(允许从数据库同步的库)
    从配置参数:
    [root@stu ~]# vim /etc/my.cnf
    log-slave-updates(允许级联复制)
    replica-do-db=库名(只同步主数据库的库名)
    replica-ignore-db=库名(不同步主数据库的库名)

    主从同步结构模式
    一主一从:(工作用的多)
    一主多从:(工作用的多)
    授权多个用户
    主主结构:
    相互授权,相互测试
    主从从:
    中间的从数据库服务器上sql线程执行本机中继日志文件里的sql命令不会被记录到本机的binlog日志文件里
    要实现最后一从数据库同步主数据库的数据,在配置文件加入允许级联复制
    [root@stu ~]# vim /etc/my.cnf
    log-slave-updates(允许级联复制)

    搭建mysql代理服务器(实现数据访问时的读写分离,减轻单台服务器的压力)
    mysql代理服务+主从同步
    在主机(192.168.4.101)daili上部署mysql代理服务器,把接受到的读请求给192.168.4.99服务器,
    把接受到的写请求给192.168.4.100服务器

    代理服务器配置:
    安装提供mysql代理服务的软件包mysql-proxy-tar.gz
    [root@daili ~]# tar -xf mysql-proxy-tar.gz(解压缩)
    [root@daili ~]# mv mysql-proxy-0.8.3-linux-rhel5-x86-64bit/ /usr/local/mysqlproxy(移动并改名)
    [root@daili mysqlproxy]# ls
    bin include lib libexec licenses share
    [root@daili mysqlproxy]# chmod +x /usr/local/mysqlproxy/share/doc/mysql-proxy/rw-splitting.lua(给脚本加执行权限)
    [root@daili mysqlproxy]# rpm -q lua(脚本死lua语言写的,查看有没有解释lua语言的包)
    lua-5.1.4-4.1.el6.x86_64
    [root@daili mysqlproxy]# netstat -utnalp | grep :3306(它监听的是3306端口,查看端口有没有被占用)
    [root@daili ~]# /usr/local/mysqlproxy/bin/mysql-proxy -P 192.168.4.101:3306 -r 192.168.4.99:3306 -b 192.168.4.100:3306 -s /usr/local/mysqlproxy/share/doc/mysql-proxy/rw-splitting.lua &
    起服务,-P 代理服务器地址:端口 -r读类型ip地址:端口 -b写类型地址:端口 -s区分访问类型的脚本 &后台运行
    [root@daili ~]# pkillmysql-proxy(结束进程)
    在两台数据库服务器做用户授权:
    mysql> grant all on *.* to hydra@"%" identified by "Anonymous";
    客户端测试访问:
    mysql -h代理服务器地址 -u用户名 -p密码(并发连接数大于4才区分读写分离)
    [root@daili ~]# mysql -h192.168.4.101 -uhydra -pAnonymous

    ————————————————————————————————————————————————————————————————————————————————————————————————————————————————————

    搭建mysql主从同步(实现数据自动备份)
    实例:
    把主机192.168.4.100的数据库配置为主机192.168.4.99的从数据库

    主数据库服务器配置
    修改配置文件:
    [root@mysql ~]# vim /etc/my.cnf
    [mysqld]
    log-bin=hydra80(启用binlog日志,从服务器主机位)
    server_id=80(从服务器主机位)
    [root@mysql ~]# /etc/init.d/mysql restart
    用户授权:
    mysql> grant replication slave on *.* to hydra@"192.168.4.100" identified by "Anonymous";

    从数据库服务器配置(从库上一定要有主库上的库)
    测试主数据库授权:
    [root@stu ~]# mysql -h192.168.4.99 -uhydra -pAnonymous
    修改配置文件:
    [root@stu ~]# vim /etc/my.cnf
    [mysqld]
    log-bin=mysql99(主服务器主机位)
    server_id=99(主服务器主机位)
    [root@stu ~]# /etc/init.d/mysqld restart

    把192.168.4.100配置为192.168.4.99的从数据库服务器
    mysql> show slave status;(查看本机是不是从服务器)
    mysql> show master status;(查看数据库的binlog日志文件名)
    配置从数据库服务器格式:
    change master to master_host="主数据库ip",master_user"授权用户",master_password="授权密码",master_log_file="主数据库的binlog日志名",master_log_pos=Position记录的数字
    测试:
    mysql>change master to master_host="192.168.4.99",master_user="hydra",master_password="Anonymous",master_log_file="hydra80.000001",master_log_pos=120;
    mysql> start slave;
    Slave_IO_Running: Yes(两个yes才可以同步数据)
    Slave_SQL_Running: Yes

    在主数据库创建数据测试
    mysql> create database hydra01;(主数据库)
    查看从数据库是否有数据库:
    mysql> show databases;(从数据库)
    hydra01

    ————————————————————————————————————————————————————————————————————————————————————

    主从同步过程
    Slave_IO_Running: io线程负责把主数据库服务器binlog日志里的sql命令同步到本机中继日志里
    IO出错的原因:iptables,selinux grat 指定的binlog日志信息错误
    报错信息Last_IO_Error:查看报错信息,排错

    Slave_SQL_Running: sql线程负责执行本机中继日志里的sql命令,把数据写入本机的库里
    SQL线程出错的原因:执行sql命令时,使用的库,表在本机不存在
    报错信息Last_SQL_Error:查看报错信息,排错

    数据库事务日志
    [root@stu ~]# ls /var/lib/mysql/
    stu-relay-bin.000001(中继日志)
    stu-relay-bin.index(中继日志的索引文件)
    relay-log.info(中继日志信息)
    master.info(连接主数据库的信息)

    让从库暂时不同步主数据库服务器的数据:
    mysql> stop slave;

    把从数据库服务器恢复为一台独立的数据库服务器:
    [root@stu ~]# rm -rf /var/lib/mysql/master.info relay-log.info stu-relay-bin.*
    [root@stu ~]# /etc/init.d/mysql restart


    主从配置的常用选项:
    [root@mysql ~]# vim /etc/my.cnf(在主数据库上配置,限制的是所有的从数据库)
    binglog-do-db=库名(允许从数据库同步的库)
    binlog-ignore-db=库名(允许从数据库同步的库)
    从配置参数:
    [root@stu ~]# vim /etc/my.cnf
    log-slave-updates(允许级联复制)
    replica-do-db=库名(只同步主数据库的库名)
    replica-ignore-db=库名(不同步主数据库的库名)

    主从同步结构模式
    一主一从:(工作用的多)
    一主多从:(工作用的多)
    授权多个用户
    主主结构:
    相互授权,相互测试
    主从从:
    中间的从数据库服务器上sql线程执行本机中继日志文件里的sql命令不会被记录到本机的binlog日志文件里
    要实现最后一从数据库同步主数据库的数据,在配置文件加入允许级联复制
    [root@stu ~]# vim /etc/my.cnf
    log-slave-updates(允许级联复制)

    搭建mysql代理服务器(实现数据访问时的读写分离,减轻单台服务器的压力)
    mysql代理服务+主从同步
    在主机(192.168.4.101)daili上部署mysql代理服务器,把接受到的读请求给192.168.4.99服务器,
    把接受到的写请求给192.168.4.100服务器

    代理服务器配置:
    安装提供mysql代理服务的软件包mysql-proxy-tar.gz
    [root@daili ~]# tar -xf mysql-proxy-tar.gz(解压缩)
    [root@daili ~]# mv mysql-proxy-0.8.3-linux-rhel5-x86-64bit/ /usr/local/mysqlproxy(移动并改名)
    [root@daili mysqlproxy]# ls
    bin include lib libexec licenses share
    [root@daili mysqlproxy]# chmod +x /usr/local/mysqlproxy/share/doc/mysql-proxy/rw-splitting.lua(给脚本加执行权限)
    [root@daili mysqlproxy]# rpm -q lua(脚本死lua语言写的,查看有没有解释lua语言的包)
    lua-5.1.4-4.1.el6.x86_64
    [root@daili mysqlproxy]# netstat -utnalp | grep :3306(它监听的是3306端口,查看端口有没有被占用)
    [root@daili ~]# /usr/local/mysqlproxy/bin/mysql-proxy -P 192.168.4.101:3306 -r 192.168.4.99:3306 -b 192.168.4.100:3306 -s /usr/local/mysqlproxy/share/doc/mysql-proxy/rw-splitting.lua &
    起服务,-P 代理服务器地址:端口 -r读类型ip地址:端口 -b写类型地址:端口 -s区分访问类型的脚本 &后台运行
    [root@daili ~]# pkillmysql-proxy(结束进程)
    在两台数据库服务器做用户授权:
    mysql> grant all on *.* to hydra@"%" identified by "Anonymous";
    客户端测试访问:
    mysql -h代理服务器地址 -u用户名 -p密码(并发连接数大于4才区分读写分离)
    [root@daili ~]# mysql -h192.168.4.101 -uhydra -pAnonymous

    ————————————————————————————————————————————————————————————————————————————————————————————————————————————————————

  • 相关阅读:
    socket网络编程
    Oracle 分区表 总结
    修改配置文件后不重启程序即时生效
    vue 计算属性
    Vue属性绑定指令 vbind
    vue虚拟dom
    vueslot插槽
    将博客搬至CSDN
    打造山寨手机中的App Store斯凯MiniJ(mrp)诞生记
    【教程】查看某个程序的占用的端口
  • 原文地址:https://www.cnblogs.com/Hydraxx/p/7486421.html
Copyright © 2011-2022 走看看