mysql主从同步是目前使用比较广泛的数据库架构,技术比较成熟,配置也不复杂,特别是对于负载比较大的网站,主从同步能够有效缓解数据库读写的压力。
mysql主从同步的机制 mysql主从同步是在mysql主从复制(master-slave replication)基础上实现的,通过设置在master mysql上的binlog(使其处于打开状态),slave mysql上通过一个i/o线程从master mysql上读取binlog,然后传输到slave mysql的中继日志中,然后slave mysql的sql线程从中继日志中读取中继日志,然后应用到slave mysql的数据库中。这样实现了主从数据同步功能。
mysql主从同步的作用1、可以作为一种备份机制,相当于热备份
2、可以用来做读写分离,均衡数据库负载
环境:
主从服务器上的mysql数据库版本同为mysql_5.1.58
主机ip:10.200.37.177
从机ip:10.200.37.178
先把mysql_5.1.58-1.rhel5.x86_64.zip文件get到服务器上。
安装mysql。
unzip mysql_5.1.58-1.rhel5.x86_64.zip
rpm -ivh mysql-client-community-5.1.58-1.rhel5.x86_64.rpm
rpm -ivh mysql-devel-community-5.1.58-1.rhel5.x86_64.rpm
rpm -ivh mysql-server-community-5.1.58-1.rhel5.x86_64.rpm
rpm -ivh mysql-shared-community-5.1.58-1.rhel5.x86_64.rpm
通过rpm 安装的mysql是没有/etc/my.cnf配置文件的。
默认路径如下:
数据库目录:/var/lib/mysql/
配置文件:/usr/share/mysql
相关命令:/usr/bin(mysqladmin、mysqldump等命令)(*mysql的一种安全启动方式:/usr/bin/mysqld_safe --user=root &)
启动脚本:/etc/rc.d/init.d/
因此,将目录/usr/share/mysql下的文件my-huge.cnf拷贝到/etc/下并改名为my.cnf
从数据库同理进行设置。
mysql主从同步的步骤一、主数据库master修改
1、修改mysql配置:
vim /etc/my.cnf
[mysqld]
# 日志文件名
log-bin=mysql-bin
# 主数据库端id号
server-id = 1
2、启动mysql,创建用于同步的账户:
/etc/init.d/mysql start
# 创建slave帐号slave_account,密码123456
mysql>grant replication slave on *.* to 'slave_account'@'%' identified by '123456';
mysql>flush privileges;
3、查询master的状态
mysql> show master status;
+------------------+----------+--------------+------------------+
| file | position | binlog_do_db | binlog_ignore_db |
+------------------+----------+--------------+------------------+
| mysql-bin.000001 | 106 | | |
+------------------+----------+--------------+------------------+
注:此时主数据库基本修改完毕。
二、从数据库slave修改
1、修改mysql配置:
vim /etc/my.cnf
# 从数据库端id号
server-id =2
2、执行同步命令
# 执行同步命令,设置主数据库ip,同步帐号密码,同步位置
mysql>change master to master_host='10.200.37.177',master_user='slave_account',master_password='123456',master_log_file='mysql-bin.000001',master_log_pos=106;
# 开启同步功能
mysql>start slave;
3、检查从数据库状态:
mysql> show slave status\g;
*************************** 1. row ***************************
slave_io_state: waiting for master to send event
master_host: 10.200.37.177
master_user: slave_account
master_port: 3306
connect_retry: 60
master_log_file: mysql-bin.000001
read_master_log_pos: 816
relay_log_file: localhost-relay-bin.000002
relay_log_pos: 961
relay_master_log_file: mysql-bin.000001
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: 816
relay_log_space: 1120
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)
注:slave_io_running及slave_sql_running进程必须正常运行,即yes状态,否则说明同步失败。
三、可能用到的相关参数
1、master端:
# 不同步哪些数据库
binlog-ignore-db = dbname
# 只同步哪些数据库,除此之外,其他不同步
binlog-do-db = dbname
# 日志保留时间
expire_logs_days = 10
# 控制binlog的写入频率。每执行多少次事务写入一次
# 这个参数性能消耗很大,但可减小mysql崩溃造成的损失
sync_binlog = 5
# 日志格式,建议mixed
# statement 保存sql语句
# row 保存影响记录数据
# mixed 前面两种的结合
binlog_format = mixed
2、slave端:
# 停止主从同步
mysql> stop slave;
# 连接断开时,重新连接超时时间
mysql> change master to master_connect_retry=50;
# 开启主从同步
mysql> start slave;
