MySql不停机添加丛库小记

  拖了很长时间才开始写这篇文章,本来打算上线之后第二天立刻开始记录的,一直有很多碎片事情要做。

  基础是已经有一主一丛,或一主多从,由于业务需要增加新的丛库来分担读的压力。查看如何配置主从复制

不停机平滑加丛库主要原理是: 

1、停掉当前的丛库同步 stop slave。做这一步之前需要需要代码层的改动,将这个从库从web业务脱离,建议访问量少时候操作。

2、查看丛库状态,show slave status  记下 Relay_Master_Log_file 和 Exec_Master_Log_Pos 

3、备份丛库,Myisam直接打包文件拷贝到另一台机器就可以了。Innodb的可以用xtrabackup备份,数据量少可以直接用Navicat数据传输,或者mysqldump导出。 

4、将数据库备份拷贝到待加丛库的机器,数据怎么弄过来方法很多,一定要保证拷贝过来的数据与上一个丛库的数据一致,数据表正常可用。 

5、编辑配置文件 my.cnf  修改 server-id (不要与之前的丛库相同) replicate-do-db(同步的库)  这两个参数

6、在新丛库设置主库的连接信息

change master to
master_host='192.168.0.xxx',
master_port=3306,
master_user='userdb_slave',     
master_password='xxxxxxxxxxxxxxxxx',
master_log_file='mysql-bin.000169',     # 上面记录的
master_log_pos=824721706;               # 上面记录的

7、重启数据库,start slave 开启同步。show slave status  

看这两个参数 Slave_IO_Running    Yes   Slave_SQL_Running   Yes  那就证明主从正常了

8、不要忘了把上一个丛库开启同步 start slave,查看上一个丛库和新加丛库是否正常同步可用,最后加入到web业务代码里面。

SQL四种语言:DDL,DML,DCL,TCL

1.DDLData Definition Language数据库定义语言statements are used to define the database structure or schema.

DDL是SQL语言的四大功能之一。
用于定义数据库的三级结构,包括外模式、概念模式、内模式及其相互之间的映像,定义数据的完整性、安全控制等约束
DDL不需要commit.
CREATE
ALTER
DROP
TRUNCATE
COMMENT
RENAME

2.DMLData Manipulation Language数据操纵语言statements are used for managing data within schema objects.

- 阅读全文 -

中文关键字搜索,出现 Illegal mix of collations for operation

  一套老程序,条件查询出现错误[Err] 1271 - Illegal mix of collations for operation 'like',打出sql,放到查询器出现这个报错。

blob.png

错误原理分析以及错误解决方法:

在 MySQL 5.5 以上, 若字段 Type 是 time,date,datetime 

在 select 時若使用 like '%中文%' 会出現 Illegal mix of collations for operation 'like'

在写程序时要对每个字段进行搜索,在执行时可能就会出现时间字段 like '%中文%' 这种语法,

这在比较久的版本MySQL是不会出现错误的。但是升级到MySQL 5.5以上,必需改成like binary '%中文%' 即可避免出现错误


我的是 blob.png,用的mysql5.6,所以就出错了。


blob.png

修改之后的sql,查询成功。

mysql 日志文件mysql-bin文件清除方法

   mysql配置了log-bin,就要设置过期删除的时间要不然会越来越多占满服务器的磁盘。


一、编辑配置文件 vim /etc/my.cnf

expire_logs_days = 10  //二进制日志自动删除的天数。

此方法需要重启mysql服务。


二、无需重启mysql服务

> show binary logs;
> show variables like '%log%';
> set global expire_logs_days = 10;


手动清除binlog文件

PURGE MASTER LOGS BEFORE DATE_SUB(CURRENT_DATE, INTERVAL 10 DAY);   //删除10天前的MySQL binlog日志