mysql集群主从切换多长时间_MySQL主从集群构建及故障切换

MYSQL数据 库主 从配置

环境准备:192.168.227.138为master主服务器,192.168.227.139o slave从服务器

在主和从服务器都安装mysql相关软件,命令如下:

yum install -y mysql-server mysql mysql-devel

安装完毕后,在Master修改vi /etc/my.cnf内容如下:

[mysqld]

datadir=/var/lib/mysql

socket=/var/lib/mysql/mysql.sock

user=mysql

# Disabling symbolic-links is recommended to prevent assorted security risks

symbolic-links=0

log-bin=mysql-bin

server-id=1

auto_increment_offset=1

auto_increment_increment=2

[mysqld_safe]

log-error=/var/log/mysqld.log

pid-file=/var/run/mysqld/mysqld.pid

replicate-do-db=all

启动mysql即可,/etc/init.d/mysqld restart

然后修改slave mysql数据库my.cnf 配置文件内容如下:

[mysqld]

datadir=/var/lib/mysql

socket=/var/lib/mysql/mysql.sock

user=mysql

# Disabling symbolic-links is recommended to prevent assorted security risks

symbolic-links=0

log-bin=mysql-bin

server-id=2

auto_increment_offset=2

auto_increment_increment=2

[mysqld_safe]

log-error=/var/log/mysqld.log

pid-file=/var/run/mysqld/mysqld.pid

master-host=192.168.227.138

master-user=root

master-pass=123456

master-port=3306

master-connect-retry=60

replicate-do-db=all

在slave 数据库服务器上设置权限,执行如下命令:

grant replication slave on *.* to 'root'@'%' identified by  '123456';

在Master数据库执行如下命令:

mysql>show master status;

然后在slava 服务器指定master ip 和同步的pos点:

mysql> change master to

-> master_host='192.168.227.138',master_user='root',master_password='123456',master_log_file='mysql-bin.000001',master_log_pos=253;

在slave启动slave start 并执行show slave\G 查看mysql主从状态

mysql> show slave status\G

*************************** 1. row ***************************

Slave_IO_State: Waiting for master to send event

Master_Host: 192.168.227.138

Master_User: root

Master_Port: 3306

Connect_Retry: 60

Master_Log_File: mysq-bin.000002

Read_Master_Log_Pos: 106

Relay_Log_File: mysqld-relay-bin.000002

Relay_Log_Pos: 250

Relay_Master_Log_File: mysq-bin.000002

Slave_IO_Running: Yes

Slave_SQL_Running: Yes

Replicate_Do_DB:

Replicate_Ignore_DB:

Replicate_Do_Table:

Replicate_Ignore_Table:

Replicate_Wild_Do_Table:

Replicate_Wild_Ignore_Table:

Last_Errno: 0

Last_Error:

Skip_Counter: 0

Exec_Master_Log_Pos: 106

Relay_Log_Space: 406

Until_Condition: None

Until_Log_File:

Until_Log_Pos: 0

Master_SSL_Allowed: No

Master_SSL_CA_File:

Master_SSL_CA_Path:

Master_SSL_Cert:

Master_SSL_Cipher:

Master_SSL_Key:

Seconds_Behind_Master: 0

Master_SSL_Verify_Server_Cert: No

Last_IO_Errno: 0

Last_IO_Error:

Last_SQL_Errno: 0

Last_SQL_Error:

1 row in set (0.00 sec)

在master主服务器上创建一个数据库,slave从服务器上会同步。

当主服务断开连接,从服务切换,修改主服务器 vi config_global.php 文件

[[email protected] html]# cd config/[[email protected] config]# ls

config_global_default.php  config_ucenter_default.php  index.htm

config_global.php          config_ucenter.php

[[email protected] config]# vi config_global.php

172243fa581a0e69289f738c4223bb33.png

修改master主服务器/var/www/html/config/config_ucenter.php

160f3c94bdf3315d8a316317ae7ed277.png

在slave从服务器上进行授权:

mysql> grant all on discuz.* to discuz@'192.168.227.138' identified by '123456';

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
MySQL集群是指将多个MySQL服务器组成一个集群,通过共享数据和负载均衡来提高系统的可靠性、可用性和性能。主从复制是MySQL集群中常用的一种技术,它通过将一个MySQL服务器作为主服务器,将其他MySQL服务器作为从服务器,实现数据的复制和同步。 主从复制的原理是,将主服务器的数据变更记录在二进制日志中,从服务器通过读取主服务器的二进制日志来实现数据的复制和同步。从服务器会定时连接主服务器,获取最新的二进制日志并将其应用到自己的数据库中,从而实现数据的同步。 主从复制可以提高系统的可用性和性能,因为从服务器可以承担读操作的负载,从而减轻主服务器的压力。同时,主从复制也可以实现数据的备份和恢复,以及数据的分析和处理等功能。 在实现主从复制时,需要注意以下几点: 1. 主从服务器的MySQL版本和配置要一致。 2. 主从服务器之间需要建立可靠的网络连接,以保证数据的同步。 3. 在主服务器上开启二进制日志记录并设置相应的参数。 4. 在从服务器上设置主服务器的信息,并开启从服务器的复制功能。 5. 注意主从服务器之间的时间同步,避免时间不同步导致数据的错误同步。 总之,主从复制是MySQL集群中一个重要的技术,可以提高系统的可靠性和性能,但也需要结合具体的业务场景和运维需求进行合理的规划和实现。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值