您好,欢迎来到三六零分类信息网!老站,搜索引擎当天收录,欢迎发信息

Mysql互为主从问题--日志同步数据不同步_MySQL

2024/3/12 23:05:17发布26次查看
bitscn.com
我搭建的是mysql 互为主从 复制
两台机器的mysql环境完全相同
第一部分测试:
b为master  a为slave的同步测试
在b上创建表lian,并插入数据
mysql> create table lian (a int,b char(10));
mysql> insert into lian (a,b)values(22,'hahah');
mysql> show tables;
+----------------+
| tables_in_test |
+----------------+
| lian           |
+----------------+
mysql> select * from lian;
+------+-------+
| a    | b     |
+------+-------+
|   22 | hahah |
+------+-------+
查看一下master-b的binlog日志,查看以上操作是否记录了日志:
cat mysql-bin.000002                                                                                                                                                                                  
.?nh?@stdtestcreate table lian (a int,b char(10))nl>@stdtestinsert into lian (a,b)values(22,'hahah')
现在查看slave-a的relay日志,发现日志已经同步了
[root@xkwb5510 var]# cat xkwb5510-relay-bin.000003                                                                                                                                                     
.?nh?@stdtestcreate table lian (a int,b char(10))nl>@stdtestinsert into lian (a,b)values(22,'hahah')
再在slave-a上看一下数据库是不是存在lian这个表:
mysql> use test;
database changed
mysql> show tables;
+----------------+
| tables_in_test |
+----------------+
| aniya          |
| lian           |
+----------------+
2 rows in set (0.00 sec)
现在说明数据b a 主 从 同步成功
---------------------------------------------------------------------------
第二部分测试:
a为master  b为slave的同步测试
在a上创建表from246,并插入数据
mysql> use test;
mysql> show tables;
+----------------+
| tables_in_test |
+----------------+
| a246           |
| aniya          |
| lian           |
+----------------+
3 rows in set (0.00 sec)
mysql> create table from246(name varchar(255),sex varchar(255),age int(10));
mysql> show tables;
+----------------+
| tables_in_test |
+----------------+
| a246           |
| from246        |
| aniya          |
| lian           |
+----------------+
4 rows in set (0.00 sec)
mysql> insert into from246 (name,sex,age)values('zhaoyj','girl',24);
mysql> select * from from246;
+--------+------+------+
| name   | sex  | age  |
+--------+------+------+
| zhaoyj | girl |   24 |
+--------+------+------+
1 row in set (0.00 sec)
查看master-a的binlog日志,证明上述操作成功
[root@xkwb5510 var]# tail -1  mysql-bin.000002
testcreate table from246(name varchar(255),sex varchar(255),age int(10))?n?r@stdtestinsert into from246 (name,sex,age)values('zhaoyj','girl',24)
查看master-a的日志状态
[root@xkwb5510 var]# /usr/local/mysql/bin/mysqlbinlog mysql-bin.000003 |tail -15
/*!*/;
# at 702
#110926 14:01:51 server id 1  end_log_pos 838  query thread_id=5 exec_time=0 error_code=0
set timestamp=1317016911/*!*/;
create table from246(name varchar(255),sex varchar(255),age int(10))
/*!*/;
# at 838
#110926 14:02:05 server id 1  end_log_pos 966  query thread_id=5 exec_time=0 error_code=0
set timestamp=1317016925/*!*/;
insert into from246 (name,sex,age)values('zhaoyj','girl',24)
/*!*/;
delimiter ;
# end of log file
rollback /* added by mysqlbinlog */;
/*!50003 set completion_type=@old_completion_type*/;
查看relay-b的日志,同步日志成功
testcreate table from246(name varchar(255),sex varchar(255),age int(10))?n?r@stdtestinsert into from246 (name,sex,age)values('zhaoyj','girl',24)[root@xkwb5705 var]
查看relay-b日志状态,可以看到日志已经同步
[root@xkwb5705 var]# /usr/local/mysql/bin/mysqlbinlog xkwb5705-relay-bin.000005|tail -13
/usr/local/mysql/bin/mysqlbinlog: character set '#28' is not a compiled character set and is not specified in the '/usr/local/mysql/share/mysql/charsets/index.xml' file
#110926 14:01:51 server id 1  end_log_pos 838  query thread_id=5 exec_time=0 error_code=0
set timestamp=1317016911/*!*/;
create table from246(name varchar(255),sex varchar(255),age int(10))
/*!*/;
# at 853
#110926 14:02:05 server id 1  end_log_pos 966  query thread_id=5 exec_time=0 error_code=0
set timestamp=1317016925/*!*/;
insert into from246 (name,sex,age)values('zhaoyj','girl',24)
/*!*/;
delimiter ;
# end of log file
rollback /* added by mysqlbinlog */;
/*!50003 set completion_type=@old_completion_type*/;
但是数据却没有插入到relay-b的数据库
mysql> show tables;
+----------------+
| tables_in_test |
+----------------+
| lian           |
+----------------+
1 row in set (0.00 sec)
当我删除master-a上的表时,relay-b日志也同步了
[root@xkwb5705 var]# tail -4 xkwb5705-relay-bin.000005                                                                                                                                                  
ns?@stdtestdrop table a246nt@stdtestdrop table aniyansd@stdtestdrop table liannv?@stdtestdrop table from246
这是什么奇怪问题 ??
------------------------------------------------------------------------------
问题排查:
首先在master-a上用
show processlist; 查看下进程是否sleep太多。发现很正常
show master status; 也正常
再跑到slave上查看 show slave status; 也正常
当我手动从a导入b数据时,发现一个问题:
mysql> load table from246 from master;
error 1115 (42000): unknown character set: 'gbk'
怀疑:难道是因为字符串的问题导致ab主从复制失败 ?
通过show character set 命令查看到
master-a有gbk字符集而slave-b没有
mysql> show character set;
+----------+-----------------------------+---------------------+--------+
| charset  | description                 | default collation   | maxlen |
+----------+-----------------------------+---------------------+--------+
| dec8     | dec west european           | dec8_swedish_ci     |      1 |
| cp850    | dos west european           | cp850_general_ci    |      1 |
| hp8      | hp west european            | hp8_english_ci      |      1 |
| koi8r    | koi8-r relcom russian       | koi8r_general_ci    |      1 |
| latin1   | cp1252 west european        | latin1_swedish_ci   |      1 |
| latin2   | iso 8859-2 central european | latin2_general_ci   |      1 |
| swe7     | 7bit swedish                | swe7_swedish_ci     |      1 |
| ascii    | us ascii                    | ascii_general_ci    |      1 |
| hebrew   | iso 8859-8 hebrew           | hebrew_general_ci   |      1 |
| koi8u    | koi8-u ukrainian            | koi8u_general_ci    |      1 |
| greek    | iso 8859-7 greek            | greek_general_ci    |      1 |
| cp1250   | windows central european    | cp1250_general_ci   |      1 |
| gbk      | gbk simplified chinese      | gbk_chinese_ci      |      2 |
| latin5   | iso 8859-9 turkish          | latin5_turkish_ci   |      1 |
| armscii8 | armscii-8 armenian          | armscii8_general_ci |      1 |
| utf8     | utf-8 unicode               | utf8_general_ci     |      3 |
| cp866    | dos russian                 | cp866_general_ci    |      1 |
| keybcs2  | dos kamenicky czech-slovak  | keybcs2_general_ci  |      1 |
| macce    | mac central european        | macce_general_ci    |      1 |
| macroman | mac west european           | macroman_general_ci |      1 |
| cp852    | dos central european        | cp852_general_ci    |      1 |
| latin7   | iso 8859-13 baltic          | latin7_general_ci   |      1 |
| cp1251   | windows cyrillic            | cp1251_general_ci   |      1 |
| cp1256   | windows arabic              | cp1256_general_ci   |      1 |
| cp1257   | windows baltic              | cp1257_general_ci   |      1 |
| binary   | binary pseudo charset       | binary              |      1 |
| geostd8  | geostd8 georgian            | geostd8_general_ci  |      1 |
+----------+-----------------------------+---------------------+--------+
27 rows in set (0.00 sec)
那现在应该是在启动mysql的时候统一他们的字符集
master-a : [root@xkwb5510 var]# /usr/local/mysql/bin/mysqld_safe --default-character-set=latin1 &
slave-b   : [root@xkwb5705 var]# /usr/local/mysql/bin/mysqld_safe --default-character-set=latin1 &
再次在b上从a导入数据:
mysql> show tables;
empty set (0.00 sec)
mysql> load table from246 from master;
query ok, 0 rows affected (0.01 sec)
mysql> show tables;
+----------------+
| tables_in_test |
+----------------+
| from246        |
+----------------+
1 row in set (0.00 sec)
现在字符集的问题解决了
---------------------------------------------------------------
现在手动启动一下“将日志应用于数据库”的线程:slave start sql_thread
和“把master段的日志写到本地”的线程:slave start io_thread
发现同步数据还是失败,那说明不是线程的问题
如果发现 seconds_behind_master 为 (null)
解决:
stop slave;
set global sql_slave_skip_counter =1 ;
start slave;
之后slave会和master去同步 主要看seconds_behind_master是否为0,直到为0时就已经同步了。。
-----------------------------------
slave b机器上master.info信息,与master a上的信息是否是同步的
mater a:
mysql> show master status/g;
*************************** 1. row ***************************
            file: mysql-bin.000004
        position: 808
    binlog_do_db: test
binlog_ignore_db: mysql
1 row in set (0.00 sec)
slave b:
[root@xkwb5705 var]# cat master.info
15
mysql-bin.000004
808
211.100.97.246
repl2
123456
3306
60
0
从以上可以看到是同步的
作者“anljf的专栏”
bitscn.com
该用户其它信息

VIP推荐

免费发布信息,免费发布B2B信息网站平台 - 三六零分类信息网 沪ICP备09012988号-2
企业名录 Product