热门标签 | HotTags
当前位置:  开发笔记 > 后端 > 正文

MySQL的复制(主从,主主,基于ssl)

1.准备的主机node1:172.16.133.11node2:172.16.133.12均已安装好MySQLMySQL安装见:5142926.blog.51cto.com51329269356522.mysql主从复制node1:主服务器

1.准备的主机node1:172.16.133.11node2:172.16.133.12均已安装好MySQLMySQL安装见:http://5142926.blog.51cto.com/5132926/9356522.mysql主从复制node1:主服务器

1.准备的主机
node1:172.16.133.11
node2:172.16.133.12
均已安装好MySQL
MySQL安装见:
2.mysql主从复制
node1:主服务器
node2:从服务器
(1)node1:
启用二进制日志(默认就是启用的)
创建具有复制权限的用户
设置server-id
node2:
启用中继日志(默认是禁用的,如果不需要的话,可以手动关闭二进制日志)
设置server-id
启动从服务,并指定主服务器参数
node1:node1中mysql服务器binary log默认就是开启的,server-id也不用修改,默认即可
创建具有复制权限的用户

  • node2:修改mysql主配置文件my.cnf中的server-id为21,注释掉log-bin=mysql-bin
    并在其后添加relay-log=mysql-relay
    完成后,进入mysql,查询下全局变量show global variables like '%log%;

  • mysql>show slave status/G查看从服务器工作状态,可以看到Slave_IO_Running: No和Slave_SQL_Running: No还是no,启用这两项

    然后就算配置完成了,可以在node1中建立一个测试数据库testdb,和一个测试表t1


    进入node2的mysql查看


    (2).如果不想让从服务器线程在mysql服务启动时自动启动,则可以在从服务器中设置skip-slave-start=1
    为防止主服务器突然崩溃,可以在主服务器上设置
    sync_binlog=1
    innodb_flush_logs_at_trx_commit=1
    (3).数据库复制过滤
    主服务器
    [mysqld]
    binlog-do-db=magedu
    在主服务器过滤:任何不涉及到数据库相关的写操作都不会被记录到二进制日志当中,所以最好不要设置,一般在从服务器中设置即可
    从服务器:
    replicate_do_db
    rpplicate_ignore_db

    replicate_do_table
    replicate_ignore_table

    replicate_wild_do_table
    replicate_wild_ignore_table
    在从服务器上只复制testdb一个数据库:
    [mysqld]
    replicate_do_db=testdb
    replicate_do_db=mysql
    (4).如果主服务器以运行很长时间,才接入一台新的从服务器,如果采取复制,会比较慢,可以采用备份的方式
    node1:先对mysql服务器施加读锁
    mysql>flush tables with read lock;
    而后对mysql所在数据目录的逻辑卷,进行备份
    lvcreate -L 50M -s -p r -n mydata-snap /dev/myvg/mydata
    mysql>show master status;查看现在所在位置


    mysql>unlocak tables(备份完成后要立即解锁)
    mount /dev/myvg/mydata-snap /mnt
    cd /mnt
    ll
    find . | cpio -o -H newc --quiet | gzip > /root/alldatabase.gz
    cd
    umount /mnt
    scp alldatabase.gz node2:/root
    mysql>use testdb
    mysql>create table tb2


    node2:
    gzip -d /root/alldatabase.gz
    cp alldatabase /data/mydata
    cd /data/mydata
    cpio -id rm alldatabase
    然后就可以直接service mysqld start
    然后进入mysql,重新设置主从
    mysql>change master to master_host='172.16.133.11',master_user='repluser',master_password='redhat',master_log_file='mysql-bin.000003',master_log_pos=542;
    mysql>start slave;
    mysql>show slave status\G
    mysql>use testdb;
    mysql>show tables
    备份+复制完成
    (5).半同步主从复制
    node1:
    mysql> INSTALL PLUGIN rpl_semi_sync_master SONAME 'semisync_master.so';
    mysql> SET GLOBAL rpl_semi_sync_master_enabled = 1;
    mysql> SET GLOBAL rpl_semi_sync_master_timeout = 1000;
    node2:
    mysql> INSTALL PLUGIN rpl_semi_sync_slave SONAME 'semisync_slave.so';
    mysql> SET GLOBAL rpl_semi_sync_slave_enabled = 1;
    mysql> STOP SLAVE IO_THREAD; START SLAVE IO_THREAD;
    也可通过设置全局变量的方式来设置,如下:
    set global rpl_semi_sync_master_enabled=1
    取消加载插件
    mysql> UNINSTALL PLUGIN rpl_semi_sync_master;
    查看从服务器上的semi_sync是否开启:
    mysql> SHOW GLOBAL STATUS LIKE 'rpl_semi%';
    查看主服务器上的semi_sync是否开启,虚拟主机,注意clients 变为1 ,证明主从半同步复制连接成功:
    (6).基于ssl传输的mysql主从复制
    ①.修改配置文件
    node1:
    server_id=10
    log_bin=mysql-bin
    sync_binlog=1事务提交后立即写入磁盘二进制文件,不再先缓存再写
    node2:
    read_Only=1
    ②准备证书,私钥
    Ⅰ.建立字签证服务器
    node1:
    vim /etc/pki/tls/openssl.cnf
    dir=/etc/pki/CA
    (umask 077;openssl genrsa 2048 > private/cakey.pem)
    openssl req -new -x509 -key private/cakey.pem -out cacert.pem -days 3655


    mkdir certs crl newcerts
    touch index.txt
    echo 01 > serial
    Ⅱ.为node1上的mysql准备私钥及颁发证书
    mkdir /usr/local/mysql/ssl
    cd ssl/
    (umask 077;openssl genrsa 1024 > mysql.key)
    openssl req -new -key mysql.key -out mysql.csr
    openssl ca -in mysql.csr -out mysql.crt
    cp /etc/pki/CA/cacert.pem /usr/local/mysql/ssl/
    Ⅲ.为node2上的mysql准备私钥及颁发证书
    mkdir /usr/local/mysql/ssl
    cd ssl/
    (umask 077;openssl genrsa 1024 > mysql.key)
    openssl req -new -key mysql.key -out mysql.csr
    scp ./mysql.csr node1:/root
    Ⅳ.为node2签发证书
    openssl ca -in mysql.csr -out mysql.crt
    scp ./mysql.crt node2:/usr/local/mysql/ssl
    cd /etc/pki/CA
    scp ./cacert.pem node2:/usr/local/mysql/ssl
    完成后,确定node1和node2中的/usr/local/mysql/ssl目录下,有这4个文件


    ③.打开mysql的ssl功能
    node1:
    mysql>show variables like '%ssl%';


    其中have_openssl,have_ssl显示为disabled,表示未开启ssl
    编辑主配置文件/etc/my.cnf在[mysqld]中添加
    ssl
    即可,重启mysql服务
    mysql>show variables like '%ssl%';


    推荐阅读
    • 本文介绍了在开发Android新闻App时,搭建本地服务器的步骤。通过使用XAMPP软件,可以一键式搭建起开发环境,包括Apache、MySQL、PHP、PERL。在本地服务器上新建数据库和表,并设置相应的属性。最后,给出了创建new表的SQL语句。这个教程适合初学者参考。 ... [详细]
    • 本文介绍了如何使用php限制数据库插入的条数并显示每次插入数据库之间的数据数目,以及避免重复提交的方法。同时还介绍了如何限制某一个数据库用户的并发连接数,以及设置数据库的连接数和连接超时时间的方法。最后提供了一些关于浏览器在线用户数和数据库连接数量比例的参考值。 ... [详细]
    • 如何实现织梦DedeCms全站伪静态
      本文介绍了如何通过修改织梦DedeCms源代码来实现全站伪静态,以提高管理和SEO效果。全站伪静态可以避免重复URL的问题,同时通过使用mod_rewrite伪静态模块和.htaccess正则表达式,可以更好地适应搜索引擎的需求。文章还提到了一些相关的技术和工具,如Ubuntu、qt编程、tomcat端口、爬虫、php request根目录等。 ... [详细]
    • 基于PgpoolII的PostgreSQL集群安装与配置教程
      本文介绍了基于PgpoolII的PostgreSQL集群的安装与配置教程。Pgpool-II是一个位于PostgreSQL服务器和PostgreSQL数据库客户端之间的中间件,提供了连接池、复制、负载均衡、缓存、看门狗、限制链接等功能,可以用于搭建高可用的PostgreSQL集群。文章详细介绍了通过yum安装Pgpool-II的步骤,并提供了相关的官方参考地址。 ... [详细]
    • 本文详细介绍了SQL日志收缩的方法,包括截断日志和删除不需要的旧日志记录。通过备份日志和使用DBCC SHRINKFILE命令可以实现日志的收缩。同时,还介绍了截断日志的原理和注意事项,包括不能截断事务日志的活动部分和MinLSN的确定方法。通过本文的方法,可以有效减小逻辑日志的大小,提高数据库的性能。 ... [详细]
    • 推荐一个ASP的内容管理框架(ASP Nuke)的优势和适用场景
      本文推荐了一个ASP的内容管理框架ASP Nuke,并介绍了其主要功能和特点。ASP Nuke支持文章新闻管理、投票、论坛等主要内容,并可以自定义模块。最新版本为0.8,虽然目前仍处于Alpha状态,但作者表示会继续更新完善。文章还分析了使用ASP的原因,包括ASP相对较小、易于部署和较简单等优势,适用于建立门户、网站的组织和小公司等场景。 ... [详细]
    • Linux服务器密码过期策略、登录次数限制、私钥登录等配置方法
      本文介绍了在Linux服务器上进行密码过期策略、登录次数限制、私钥登录等配置的方法。通过修改配置文件中的参数,可以设置密码的有效期、最小间隔时间、最小长度,并在密码过期前进行提示。同时还介绍了如何进行公钥登录和修改默认账户用户名的操作。详细步骤和注意事项可参考本文内容。 ... [详细]
    • 本文介绍了在rhel5.5操作系统下搭建网关+LAMP+postfix+dhcp的步骤和配置方法。通过配置dhcp自动分配ip、实现外网访问公司网站、内网收发邮件、内网上网以及SNAT转换等功能。详细介绍了安装dhcp和配置相关文件的步骤,并提供了相关的命令和配置示例。 ... [详细]
    • 图解redis的持久化存储机制RDB和AOF的原理和优缺点
      本文通过图解的方式介绍了redis的持久化存储机制RDB和AOF的原理和优缺点。RDB是将redis内存中的数据保存为快照文件,恢复速度较快但不支持拉链式快照。AOF是将操作日志保存到磁盘,实时存储数据但恢复速度较慢。文章详细分析了两种机制的优缺点,帮助读者更好地理解redis的持久化存储策略。 ... [详细]
    • 本文介绍了通过mysql命令查看mysql的安装路径的方法,提供了相应的sql语句,并希望对读者有参考价值。 ... [详细]
    • 图片复制到服务器 方向变了_双服务器热备更新配置文件步骤问题及解决方法
      本文介绍了在将图片复制到服务器并进行方向变换的过程中,双服务器热备更新配置文件所出现的问题及解决方法。通过停止所有服务、更新配置、重启服务等操作,可以避免数据中断和操作不规范导致的问题。同时还提到了注意事项,如Avimet版本的差异以及配置文件和批处理文件的存放路径等。通过严格执行切换步骤,可以成功进行更新操作。 ... [详细]
    • 本文介绍了在mac环境下使用nginx配置nodejs代理服务器的步骤,包括安装nginx、创建目录和文件、配置代理的域名和日志记录等。 ... [详细]
    • mysql-cluster集群sql节点高可用keepalived的故障处理过程
      本文描述了mysql-cluster集群sql节点高可用keepalived的故障处理过程,包括故障发生时间、故障描述、故障分析等内容。根据keepalived的日志分析,发现bogus VRRP packet received on eth0 !!!等错误信息,进而导致vip地址失效,使得mysql-cluster的api无法访问。针对这个问题,本文提供了相应的解决方案。 ... [详细]
    • ubuntu用sqoop将数据从hive导入mysql时,命令: ... [详细]
    • mac php错误日志配置方法及错误级别修改
      本文介绍了在mac环境下配置php错误日志的方法,包括修改php.ini文件和httpd.conf文件的操作步骤。同时还介绍了如何修改错误级别,以及相应的错误级别参考链接。 ... [详细]
    author-avatar
    藏A组合别_577
    这个家伙很懒,什么也没留下!
    PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
    Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有