MySQL-复制(1)

  复制通常的用途:

1 数据分布( Data Distribution , MySQL 的复制通常不会对带宽造成很大的压力,并且可以随意启动和停止,因此,它对于在不同的地方维护数据拷贝很有作用,比如在各个数据中心之间,远方的从服务器甚至可以使用断断续续的连接。但是需要从服务器有很低的复制延迟,那么就需要稳定、低延迟的连接。

                2 负载平衡( Load Balancing , MySQL 复制可以把读取分布在不同的服务器上,这对于读取密集型的程序效果很好。可以对代码做一下简单的更改实现基本的负载均衡。可以使用小规模的更改,比如在代码里面硬编码主机名并使用循环域名服务器 ( 它把一个主机名指定给多个 IP 地址 ) 。还可以采用复杂的方式,例如实现负载平衡的网络产品也能在 mysql 服务器之间分布负载

               3 备份 (Backups) ,复制对备份很有帮助。但是从服务器既不是备份,也不是备份的替代品。

               4 高可用性和故障转移 (High Availability and Failover) ,复制可以避免在应用程序中出现 Mysql 失效。好的故障转移系统包括了能显著减少故障停机时间的复制服务器。

           5 测试 Mysql 升级 (Testing MysqlUpgrade) ,一个常见的实践就是在把所有的服务器升级到新版本之前,使用从服务器安装 mysql 升级版本,然后用它来测试查询,确保查询按照想要的方式工作。

 

复制的工作原理:

           1 主服务器把数据更改记录到二进制日志中。 ( 这叫做二进制日志事件 )

           2 从服务器把主服务器的二进制日志事件拷贝到自己的中继日志中。

           3 从服务器重放中继日志中的事件,把更改应用到自己的数据上。

创建复制:

            1 在每一台服务器上创建复制账号。

                I/O 线程运行在从服务器上,它创建了到主服务器的连接。这意味着必须在主服务器上创建一个用户账号并且给它合适的权限,这样 I/O 线程就可以以这个用户的身份连接主服务器,并且读取它的二进制日志,下面是创建用户的例子,用户名 netschina

               Mysql> grant replication slave,replication client on *.* to netschina@’192.168.1.% ’ identified by ‘123456’;

 

            2 正确配置主、从服务器

               在主服务器上开启有些设置,假设主服务器是 server1, 这时需要打开二进制日志并定义一个服务器 ID ,在主服务器的 my.conf 或者 my.ini 文件中输入下面的配置行 ( 实际的值取决于你自己 )

                 log_bin = mysql-bin        

                 server_id = 10

 

             可通过如下命令行验证二进制日志文件是否已被创建: show master status;

             

             从服务器也要和主服务器类似的配置,并且也要在从服务器上重启 mysql.

               log_bin          = mysql-bin

             server_id         = 2

             relay_log          = mysql-relay-bin

             log_slave_updates = 1

             read_only        = 1

            

            3 指导从服务器进行连接与复制

             这一步要告诉从服务器如何连接主服务器并中继其二进制日志。不要为这个使用 mysql 的配置文件,而应该使用 change master to 命令,这个命令完全代替了相应的配置文件设置,它可以让你在以后把从服务器指向不同的主服务器,并且不用停止服务器,下面是一个复制的基础命令: mysql> change master to master_host=’server1’,

                                  > master_user=’netschina’,

                                  > master_password=’netschina’,

                                  > master_log_file=’mysql-bin.000001’,

                                  > master_log_pos=0;

在以上命令运行后可通过 show slave status/G 来查看从服务器的设置是否正确

 

之后运行下面的命令开始复制: mysql> start slave; 这个命令不会出错,也不会有输出,再次用 show slave status ; 查看

 

其实还可以在查看主、从服务器的线程来检查设置的对与否,运行如下命令

  Mysql > show processlist /G

  在主服务器上应该可以看到从服务器 I/O 线程创建的连接

  在从服务器上应该可以看到两个线程。一个是 I/O 线程,另一个是 sql 线程

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值