设为首页收藏本站

LinuxTone | 运维专家网论坛 - 最棒的Linux运维与开源架构技术交流社区!

 找回密码
 注册

用新浪微博连接

一步搞定

QQ登录

只需一步,快速开始

查看: 4985|回复: 11

[MySQL管理] mysql M/S配置小记--最基础的东西   [复制链接]

LT管理团队

守住每一天

Rank: 9Rank: 9Rank: 9

签到
195
注册时间
2008-5-30
最后登录
2012-5-23
在线时间
641 小时
阅读权限
200
积分
16234
帖子
1273
主题
176
精华
11
UID
31
发表于 2008-6-3 09:53:43 |显示全部楼层
昨天做了MYSQL 主从服务器同步配置。今天早上起了个大早,到现在还是睡意朦胧。。。
现在写下整个同步过程及需要注意的地方
目前情况:
1.系统版本都是rhel5 mysql版本相同
2.主服务器正在运行,不能停止。
3.主服务器IP为:10.0.0.2
  从服务器IP为:10.0.0.3
4.从服务器MSYQL slave 为停止状态
配置过程:
1、为了安全起见,建同步账号

mysql> GRANT REPLICATION SLAVE ON *.*  
    -> TO 'repl'@'%.mydomain.com' IDENTIFIED BY 'slavepass';




本例: GRANT REPLICATION SLAVE ON *.* TO
mysqlms@10.0.0.3 IDENTIFIED BY mysqlslave;
2、锁表

mysql > FLUSH TABLES WITH READ LOCK;


注意:为了保证FLUSH TABLES语句让读锁定保持有效。(如果退出客户程序,锁被释放)。建立新的SSH连接,然后对主服务器上的数据进行快
照。
3、建立快照

tar -cvf /tmp/mysql-snapshot.tar ./data


数据库大怎么办?用mysqldump导出。
本例:tar -cvf /tmp/mysql-snapshot.tar ./data/newnew  --其中的一个数据库,其它的无关紧要。
4、记下file pos值
当FLUSH TABLES WITH READ LOCK所置读锁定有效时,读取主服务器上当前的二进制日志名(file)和偏移量值(pos):
mysql > SHOW MASTER STATUS;
+---------------+----------+--------------+------------------+
| File          | Position | Binlog_Do_DB | Binlog_Ignore_DB |
+---------------+----------+--------------+------------------+
| mysql-bin.003 | 73       | test         | manual,mysql     |
+---------------+----------+--------------+------------------+

File列显示日志名,而Position显示偏移量。在该例子中,二进制日志值为mysql-bin.003,偏移量为73。记录该值。以后设置从服务器时需要
使用这些值。它们表示复制坐标,从服务器应从该点(也可以是任何点)开始从主服务器上进行新的更新。
5、解锁

mysql > UNLOCK TABLES;

这时也可以使用mysql > SHOW MASTER STATUS; 查看pos在不断的变化。
6、配置主从服务器my.cnf


[mysqld]  
log-bin=mysql-bin  
server-id=1





[mysqld]  
log-bin=mysql-bin  
server-id=2


7、将主服务器快照信息COPY至从服务器,重启从服务器MYSQL,并配置MASTER
# scp /tmp/mysql-snapshot.tar [email=root@10.0.0.3:/root]root@10.0.0.3:/root[/email]
# 在从服务器解压,覆盖data,注意权限
#从服务器操作 service mysqld restart

# mysql> CHANGE MASTER TO  
->     MASTER_HOST='master_host_name',  
->     MASTER_USER='replication_user_name',  
->     MASTER_PASSWORD='replication_password',  
->     MASTER_LOG_FILE='recorded_log_file_name',  
->     MASTER_LOG_POS=recorded_log_position;


本例:
# mysql> CHANGE MASTER TO
->     MASTER_HOST='10.0.0.2',
->     MASTER_USER='mysqlms',
->     MASTER_PASSWORD='mysqlslave',
->     MASTER_LOG_FILE='mysql-bin.003',
->     MASTER_LOG_POS=73;   


----这些信息在主服务器用mysql > SHOW MASTER STATUS;查看得知。
8、验证配置是否正确
登录从服务器输入如下命令:

mysql> show slave status\G


会得到类似下面的列表:

Slave_IO_Running: Yes
Slave_SQL_Running: Yes



9、启动同步
从服务器

mysql> start slave;


10、再次验证同步
在主服务器建个表,在从服务器查看是否也有。


附:
一些错误信息的处理,主从服务器上的命令,及状态信息。
在从服务器上使用show slave status\G
Slave_IO_Running,为No,
则说明IO_THREAD没有启动,请执行start slave io_thread
Slave_SQL_Running为No
则复制出错,查看Last_error字段排除错误后执行start slave sql_thread
查看Slave_IO_State字段空 //复制没有启动
Connecting to master//没有连接上master
Waiting for master to send event//已经连上
主服务器上的相关命令:
show master status
show slave hosts
show logs
show binlog events
purge logs to 'log_name'
purge logs before 'date'
reset master(老版本flush master)
set sql_log_bin=

从服务器上的相关命令:
slave start
slave stop
SLAVE STOP IO_THREAD //此线程把master段的日志写到本地
SLAVE start IO_THREAD
SLAVE STOP SQL_THREAD //此线程把写到本地的日志应用于数据库
SLAVE start SQL_THREAD
reset slave
SET GLOBAL SQL_SLAVE_SKIP_COUNTER
load data from master
show slave status(SUPER,REPLICATION CLIENT)
CHANGE MASTER TO MASTER_HOST=, MASTER_PORT=,MASTER_USER=, MASTER_PASSWORD= //动态改变master信息
PURGE MASTER [before 'date'] 删除master端已同步过的日志

6.3.1 Master 同步线程状态
以下列出了master的 Binlog Dump 线程 State 字段中最常见的几种状态。如果在master上没有 Binlog Dump 线程,那么同步就没有在运行。
也就是说,没有slave连接上来。

Sending binlog event to slave
事件是由二进制日志构成,一个事件通常由更新语句加上其他信息。线程读取到一个事件并正发送到slave上。

Finished reading one binlog; switching to next binlog
读取完了一个二进制日志,正切换到下一个。

Has sent all binlog to slave; waiting for binlog to be updated
已经读取完全部未完成更新日志,并且全部都发送到slave了。它处于空闲状态,正等待在master上执行新的更新操作以在二进制日志中产生新
的事件,然后读取它们。

Waiting to finalize termination
当前线程停止了,这个时间很短。

6.3.2 Slave的I/O线程状态
以下列出了slave的I/O线程 State 字段中最常见的几种状态。从MySQL 4.1.1开始,这个状态在执行 SHOW SLAVE STATUS 语句结果的
Slave_IO_State 字段也会出现。这意味着可以只执行 SHOW SLAVE STATUS 语句就能了解到更多的信息。

Connecting to master
该线程证尝试连接到master上。

Checking master version
确定连接到master后出现的一个短暂的状态。

Registering slave on master
确定连接到master后出现的一个短暂的状态。

Requesting binlog dump
确定连接到master后出现的一个短暂的状态。该线程向master发送一个请求,告诉它要请求的二进制文件以及开始位置。

Waiting to reconnect after a failed binlog dump request
如果二进制日志转储(binary log dump)请求失败了(由于连接断开),该线程在休眠时进入这个状态,并定期重连。重连的时间间隔由 --
master-connect-retry 选项来指定。

Reconnecting after a failed binlog dump request
该线程正尝试重连到master。

Waiting for master to send event
已经连接到master,正等待它发送二进制日志。如果master闲置时,这个状态可能会持续较长时间,如果它等待超过 slave_read_timeout 秒
,就会发生超时。这时,它就会考虑断开连接,然后尝试重连。

Queueing master event to the relay log
已经读取到一个事件,正把它拷贝到中继日志中以备SQL线程处理。

Waiting to reconnect after a failed master event read
读日志时发生错误(由于连接断开)。该线程在重连之前休眠 master-connect-retry 秒。
Reconnecting after a failed master event read

正尝试重连到master。当连接确定后,状态就变成 Waiting for master to send event。
Waiting for the slave SQL thread to free enough relay log space
relay_log_space_limit 的值非零,中继日志的大小总和超过这个值了。I/O线程等待SQL线程先处理中继日志然后删除它们以释放足够的空间

Waiting for slave mutex on exit
当前线程停止了,这个时间很短。

6.3.3 Slave的SQL线程状态
以下列出了slave的SQL线程 State 字段中最常见的几种状态:

Reading event from the relay log
从中继日志里读到一个事件以备执行。

Has read all relay log; waiting for the slave I/O thread to update it
已经处理完中继日志中的全部事件了,正等待I/O线程写入更新的日志。

Waiting for slave mutex on exit
当前线程停止了,这个时间很短。


本文一些信息来自互联网,如有版权问题请与我联系
已有 1 人评分积分 收起 理由
linuxtone + 10 原创内容

总评分: 积分 + 10   查看全部评分

Rank: 2

注册时间
2008-7-15
最后登录
2009-1-18
在线时间
25 小时
阅读权限
20
积分
106
帖子
72
主题
10
精华
2
UID
139

LT粉丝

发表于 2008-7-19 16:04:51 |显示全部楼层
仔细看过

使用道具 举报

Rank: 2

注册时间
2008-11-21
最后登录
2011-4-11
在线时间
66 小时
阅读权限
20
积分
182
帖子
99
主题
14
精华
0
UID
596

LT粉丝

发表于 2009-4-20 15:31:18 |显示全部楼层
些的还可以!

使用道具 举报

论坛元老

举子

Rank: 8Rank: 8

注册时间
2010-1-12
最后登录
2012-5-21
在线时间
444 小时
阅读权限
90
积分
15184
帖子
734
主题
121
精华
0
UID
7522
发表于 2011-1-4 00:38:06 |显示全部楼层
顶贴!            

使用道具 举报

论坛元老

小运维(总有一天我可以是‘老运维’)

Rank: 8Rank: 8

注册时间
2010-11-12
最后登录
2012-5-23
在线时间
722 小时
阅读权限
90
积分
19850
帖子
409
主题
20
精华
0
UID
11131
发表于 2011-1-4 08:15:45 |显示全部楼层
好文我UP!

使用道具 举报

Rank: 8Rank: 8

注册时间
2010-8-26
最后登录
2012-5-23
在线时间
281 小时
阅读权限
90
积分
12865
帖子
87
主题
4
精华
0
UID
10216
发表于 2011-1-4 08:56:14 |显示全部楼层
顶贴!不错

使用道具 举报

Rank: 4

注册时间
2010-3-11
最后登录
2012-4-16
在线时间
19 小时
阅读权限
50
积分
884
帖子
27
主题
0
精华
0
UID
8250
发表于 2011-2-9 10:23:55 |显示全部楼层
开始学习!!!

使用道具 举报

Rank: 8Rank: 8

注册时间
2009-9-7
最后登录
2012-5-21
在线时间
215 小时
阅读权限
90
积分
7076
帖子
47
主题
5
精华
0
UID
5243
发表于 2011-2-9 13:50:29 |显示全部楼层
清晰明了,学习了...

使用道具 举报

Rank: 2

注册时间
2010-2-8
最后登录
2011-4-21
在线时间
18 小时
阅读权限
20
积分
92
帖子
11
主题
2
精华
0
UID
7904
发表于 2011-2-10 11:57:32 |显示全部楼层
各种看不懂啊....我杯具..

使用道具 举报

Rank: 6Rank: 6

注册时间
2009-1-22
最后登录
2012-5-21
在线时间
45 小时
阅读权限
70
积分
1398
帖子
85
主题
5
精华
0
UID
1152
发表于 2011-2-10 14:11:18 |显示全部楼层
感谢分享,好东西一定要支持。

使用道具 举报

论坛元老

(左_左)

Rank: 8Rank: 8

注册时间
2011-1-8
最后登录
2012-5-22
在线时间
499 小时
阅读权限
90
积分
27217
帖子
676
主题
19
精华
0
UID
11710
发表于 2011-2-11 22:24:09 |显示全部楼层
好   文章

使用道具 举报

LT技术团队

MySQL DBA

Rank: 7Rank: 7Rank: 7

注册时间
2009-10-19
最后登录
2012-5-7
在线时间
54 小时
阅读权限
100
积分
2458
帖子
88
主题
31
精华
0
UID
6006
发表于 2011-2-12 00:03:07 |显示全部楼层
如果都是InnoDB的表,可以直接在主库一个事务中导出所有数据和Change Master信息,
mysqldump -uroot -p --all-databases --opt --add-drop-database --add-drop-table --events --triggers --routines --default-character-set=utf8 --master-data=2  --single-transaction --complete-insert --quote-names --log-error=/tmp/mysqldump.log >backup.sql
<-sina_sign,1653584493,1->

使用道具 举报

您需要登录后才可以回帖 登录 | 注册

IT运维专家网感谢红之盟网络提供带宽支持

合作联系: QQ:67888954/MSN:cnseek@msn.com/mail:netseek@linuxtone.org

Archiver|手机版|感谢所有关心和支持过LinuxTone的朋友们 转载本站内容请注明原作者名及出处 ( 京ICP备08103151 )   |

GMT+8, 2012-5-23 10:28 , Processed in 0.133603 second(s), 13 queries , Memcache On.

Powered by Discuz! X2

© 2001-2011 Comsenz Inc.

回顶部