mysql主从复制

构建MySQL主从复制

-----------主MySQL------------从MySQL----------从MySQL------------
        192.168.1.1         192.168.1.2      192.168.1.3

MySQL的主从复制和mysql的读写分离两者有着紧密联系,数据的读写分离实在主从复制的基础之上完成的,也就是说只有主从复制完成了,才能在此基础上做数据读写分离

MySQL支持的复制类型:

 1.基于语句的复制:在主服务器上执行的SQL语句,在从服务器上再执行同样的语句句,默认采用基于语的
复制,效率比较高
 2.基于行的复制:把改变的内容复制过去,而不是把命令在从服务器上执行一遍 (比较精准)
 3.混合类型的复制:默认采用基于语的复制,一旦发现基于语句无法精确复制时,就会采用基于行的复制

一、准备工作

1.保证服务器之间正常通讯
2.保证时间同步一至

1、配置IP地址
2、关闭防火墙
[root@localhost ~]# service iptables stop
[root@localhost ~]# chkconfig iptables off

二、时间同步服务器

1、在主数据库上搭建NTP时间同步服务器

[root@localhost ~]# yum -y install ntp
[root@localhost ~]# vim /etc/ntp.conf
添加:
server 127.127.1.0
fudge 127.127.1.0 stratum 8
[root@localhost ~]# service ntpd restart
2、在从数据库上安装ntp时间服务
[root@localhost ~]# yum -y install ntpdate
[root@localhost ~]# ntpdate 192.168.1.1

二、安装MySQL服务(三台数据库服务器安装保持一致)

1、安装cmake软件
[root@localhost ~]# tar -zxvf cmake-2.8.6.tar.gz -C /usr/src/
[root@localhost ~]# cd /usr/src/cmake-2.8.6/
[root@localhost cmake-2.8.6]# ./configure && gmake && gmake install
2、安装mysql软件
[root@localhost ~]# tar -zxvf mysql-5.5.22.tar.gz -C /usr/src/
[root@localhost ~]# cd /usr/src/mysql-5.5.22/
[root@localhost mysql-5.5.22]# cmake  DCMAKE_INSTALL_PREFIX=/usr/local/mysql
 -DDEFAULT_CHARSET=utf8 -DDEFAULT_COLLATION=utf8_general_ci -DSYSCONFDIR=/etc 
 -DWITH_EXTRA_CHARSETS=all
[root@localhost mysql-5.5.22]# make && make install
[root@localhost ~]# cp /usr/src/mysql-5.5.22/support-files/mymedium.cnf /etc/my.cnf
[root@localhost ~]# cp /usr/src/mysql-5.5.22/support-files/mysql.server 
/etc/init.d/mysqld
[root@localhost ~]# chmod +x /etc/init.d/mysqld
[root@localhost ~]# chown -R mysql:mysql /usr/local/mysql
[root@localhost ~]# ln -s /usr/local/mysql/bin/* /usr/local/bin/
[root@localhost ~]# /usr/local/mysql/scripts/mysql_install_db --
user=mysql --basedir=/usr/local/mysql/ --datadir=/usr/local/mysql/data/
[root@localhost ~]# service mysqld restart
[root@localhost ~]# chkconfig --add mysqld
[root@localhost ~]# chkconfig mysqld on
验证:
[root@localhost ~]# mysqladmin -u root password '123.com'
[root@localhost ~]# mysql -u root -p123.com
3、主从配置
1)主数据库服务器配置
[root@localhost ~]# vim /etc/my.cnf
添加:
server-id=11 //修改
log-bin=master-bin //修改 启用二进制
log-slave-updates=true //添加 允许从服务器同步
[root@localhost ~]# service mysqld restart
[root@localhost ~]# mysql -u root -p123.com
   mysql> grant replication slave on *.* to 'slave'@'192.168.1.%' identified by '123.com';
   mysql> flush privileges;
   mysql> show master status;                                                      
   mysql> quit
2)从数据库服务器配置
[root@localhost ~]# vim /etc/my.cnf
添加:
server-id=22 //修改  :主—从的ID不能相同。
relay-log=relay-log-bin //添加
relay-log-index=slave-relay-bin.index //添加

[root@localhost ~]# service mysqld restart
[root@localhost ~]# mysql -u root -p123.com
mysql> change master to
master_host='192.168.1.1',master_user='slave',master_password='123.com',master_log_file='mast
er-bin.000001',master_log_pos=107;
mysql> start slave;
mysql> show slave status\G; //结尾不能加; 否则或报错。
Slave_IO_Running: Yes //确保为YES
Slave_SQL_Running: Yes //确保为YES
mysql> quit
问题说明:
1、如果出现ERROR: No query specified
则:原因是语法错误,去掉语句后的;号。
2、如果bin-log日志不更新,或者无法进行数据同步,
则:删除bin-log日志,重新启动服务即可。
4、验证:
1)主数据库服务器:
[root@localhost ~]# mysql -u root -p123.com
   mysql> show databases;
   mysql> create database hehe;
   mysql> show databases;
   mysql> use hehe;
   mysql> create table biao1 (id int(5),name char(12));
   mysql> show tables;
   mysql> quit
2)从数据库服务器:
 [root@localhost ~]# mysql -u root -p123.com
   mysql> show databases;
   mysql> show databases;
   mysql> use hehe
   mysql> show tables;
   mysql> quit
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 206,126评论 6 481
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 88,254评论 2 382
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 152,445评论 0 341
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 55,185评论 1 278
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 64,178评论 5 371
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,970评论 1 284
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,276评论 3 399
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,927评论 0 259
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 43,400评论 1 300
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,883评论 2 323
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,997评论 1 333
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,646评论 4 322
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,213评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,204评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,423评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,423评论 2 352
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,722评论 2 345

推荐阅读更多精彩内容