1.下载mysql-5.5.42、mysql-5.6.23到/usr/local目录下
cd /usr/local wget http://cdn.mysql.com/Downloads/MySQL-5.5/mysql-5.5.42-linux2.6-x86_64.tar.gz wget http://cdn.mysql.com/Downloads/MySQL-5.6/mysql-5.6.23-linux-glibc2.5-x86_64.tar.gz
2.解压mysql-5.5.42程序到/usr/local/目录下
tar zcf /usr/local/mysql-5.5.42-linux2.6-x86_64.tar.gz .
3.获取root权限
1.确认当前待升级的 db server为只读状态,如果不是,则设置为只读
show global variables like 'read_only'; SET global read_only=true;
2.确认slave禁用了程序启动后自动开启复制,如果没有禁用则修改mysql配置文件禁止mysql自动开启复制
grep 'skip-slave-start' /etc/mysql/my.cnf
2.关闭slave复制线程,并记录复制点
STOP SLAVE; SHOW SLAVE STATUS \G
3.关闭mysql slave server
/etc/init.d/mysql stop
4.替换MySQL程序为新的版本
cd /usr/local/ mv mysql mysql-5.1 mv mysql-5.5.42 mysql mv /etc/init.d/mysql /etc/init.d/mysql-5.1 cp /usr/local/mysql/support-files/mysql.server /etc/init.d/mysql
6.启动MySQL服务并执行升级程序
/etc/init.d/mysql start/usr/local/mysql/bin/mysql_upgrade --skip-write-binlog -udbadmin -p
7.重启MySQL服务
/etc/init.d/mysql stop /etc/init.d/mysql start
8.验证MySQL版本及可用性
SELECT @@version;
USE test; -- 创建测试表 CREATE TABLE test.mysql_upgrade_test (is_upgrade_success enum('true','false') NOT NULL DEFAULT 'true') ENGINE=InnoDB DEFAULT CHARSET=latin1; -- 验证insert操作 INSERT INTO test.mysql_upgrade_test (is_upgrade_success) VALUES ('false'); -- 验证update操作 UPDATE test.mysql_upgrade_test SET is_upgrade_success='true'; -- 验证 select 操作 SELECT * FROM test.mysql_upgrade_test; -- 验证 delete 操作 DELETE FROM test.mysql_upgrade_test; -- 删除测试表 DROP TABLE test.mysql_upgrade_test;
9.启动slave复制
START SLAVE;
10.观察复制是否正常
SHOW SLAVE STATUS \G
1.确认vt web db slave是否为只读,如果不是,则将其设为只读
SHOW GLOBAL VARIABLES LIKE 'read_only'; SET GLOBAL read_only = on;
2.停止keepalived应用程序,使应用切换到slave上。
/etc/init.d/keepalived stop
3.确认master禁用了自动开启复制。如果没有禁用,则修改mysql配置文件禁止mysql自动开启复制
grep 'skip-slave-start' /etc/mysql/my.cnf
4.关闭复制线程,并记录复制点
STOP SLAVE; SHOW SLAVE STATUS \G
5.关闭mysql slave server
/etc/init.d/mysql stop
6.替换MySQL程序为新的版本
cd /usr/local/ mv mysql mysql-5.1 mv mysql-5.5.42 mysql mv /etc/init.d/mysql /etc/init.d/mysql-5.1 cp /usr/local/mysql/support-files/mysql.server /etc/init.d/mysql
6.启动MySQL服务并执行升级程序(注意:升级master的时候要加上--skip-write-binlog参数,避免升级操作通过binlog同步到slave上)
/etc/init.d/mysql start/usr/local/mysql/bin/mysql_upgrade --skip-write-binlog -udbadmin -p
7.重启MySQL服务
/etc/init.d/mysql stop /etc/init.d/mysql start
8.验证MySQL版本及可用性
SELECT @@VERSION;
USE test; -- 创建测试表 CREATE TABLE test.mysql_upgrade_test (is_upgrade_success enum('true','false') NOT NULL DEFAULT 'true') ENGINE=InnoDB DEFAULT CHARSET=latin1; -- 验证insert操作 INSERT INTO test.mysql_upgrade_test (is_upgrade_success) VALUES ('false'); -- 验证update操作 UPDATE test.mysql_upgrade_test SET is_upgrade_success='true'; -- 验证 select 操作 SELECT * FROM test.mysql_upgrade_test; -- 验证 delete 操作 DELETE FROM test.mysql_upgrade_test; -- 删除测试表 DROP TABLE test.mysql_upgrade_test;
9.启动slave复制
START SLAVE;
10.观察复制是否正常
SHOW SLAVE STATUS \G
13.相关命令
1). 采取先slave后master的升级方式。master升级异常,在规定时间内无法修复,可以切换到slave提供服务。
2).最近在升级一个带分区表的库时,其中有两张表在升级过程中由于分区采用KEY分区方式,升级时脚本报错,如下:
host-a:/usr/local# /usr/local/mysql/bin/mysql_upgrade -udbadmin -p
Enter password:
Looking for 'mysql' as: /usr/local/mysql/bin/mysql
Looking for 'mysqlcheck' as: /usr/local/mysql/bin/mysqlcheck
Running 'mysqlcheck' with connection arguments: '--port=3306' '--socket=/tmp/mysql.sock'
Running 'mysqlcheck' with connection arguments: '--port=3306' '--socket=/tmp/mysql.sock'
xtaisan.video_slideshowInfo OK
xtaisan.video_trackingMeta
error : KEY () partitioning changed, please run:
ALTER TABLE `xtaisan`.`video_trackingMeta` PARTITION BY RANGE (video_id)
SUBPARTITION BY KEY /*!50531 ALGORITHM = 1 */ (video_id)
SUBPARTITIONS 4
(PARTITION p_1 VALUES LESS THAN (2400000000) ENGINE = InnoDB,
PARTITION p_2 VALUES LESS THAN (2500000000) ENGINE = InnoDB,
PARTITION p_3 VALUES LESS THAN (2600000000) ENGINE = InnoDB,
PARTITION p_4 VALUES LESS THAN (2700000000) ENGINE = InnoDB,
PARTITION p_5 VALUES LESS THAN (2800000000) ENGINE = InnoDB,
PARTITION p_6 VALUES LESS THAN (2900000000) ENGINE = InnoDB,
PARTITION p_7 VALUES LESS THAN (3000000000) ENGINE = InnoDB,
PARTITION p_max VALUES LESS THAN MAXVALUE ENGINE = InnoDB)
status : Operation failed
xtaisan.video_trackingMetaFinished
error : KEY () partitioning changed, please run:
ALTER TABLE `xtaisan`.`video_trackingMetaFinished` PARTITION BY RANGE (video_id)
SUBPARTITION BY KEY /*!50531 ALGORITHM = 1 */ (video_id)
SUBPARTITIONS 4
(PARTITION p_1 VALUES LESS THAN (2400000000) ENGINE = InnoDB,
PARTITION p_2 VALUES LESS THAN (2500000000) ENGINE = InnoDB,
PARTITION p_3 VALUES LESS THAN (2600000000) ENGINE = InnoDB,
PARTITION p_4 VALUES LESS THAN (2700000000) ENGINE = InnoDB,
PARTITION p_5 VALUES LESS THAN (2800000000) ENGINE = InnoDB,
PARTITION p_6 VALUES LESS THAN (2900000000) ENGINE = InnoDB,
PARTITION p_7 VALUES LESS THAN (3000000000) ENGINE = InnoDB,
PARTITION p_max VALUES LESS THAN MAXVALUE ENGINE = InnoDB)
status : Operation failed
xtaisan.video_trackingMetaNewVDNA OK
......
xvstool.websites OK
Running 'mysql_fix_privilege_tables'...
OK
root@EQX-148:/usr/local#
解决办法:
dbadmin@(none) 04:32:13>ALTER TABLE `xtaisan`.`video_trackingMeta` PARTITION BY RANGE (video_id)
-> SUBPARTITION BY KEY /*!50531 ALGORITHM = 1 */ (video_id)
-> SUBPARTITIONS 4
-> (PARTITION p_1 VALUES LESS THAN (2400000000) ENGINE = InnoDB,
-> PARTITION p_2 VALUES LESS THAN (2500000000) ENGINE = InnoDB,
-> PARTITION p_3 VALUES LESS THAN (2600000000) ENGINE = InnoDB,
-> PARTITION p_4 VALUES LESS THAN (2700000000) ENGINE = InnoDB,
-> PARTITION p_5 VALUES LESS THAN (2800000000) ENGINE = InnoDB,
-> PARTITION p_6 VALUES LESS THAN (2900000000) ENGINE = InnoDB,
-> PARTITION p_7 VALUES LESS THAN (3000000000) ENGINE = InnoDB,
-> PARTITION p_max VALUES LESS THAN MAXVALUE ENGINE = InnoDB);
Query OK, 19386611 rows affected (22 min 49.71 sec)
Records: 19386611 Duplicates: 0 Warnings: 0
1.升级备份工具、监控程序等
附:
MySQL版本下载链接MySQL5.1 http://downloads.mysql.com/archives/get/file/mysql-5.1.57-linux-i686-glibc23.tar.gz
MySQL5.5 http://cdn.mysql.com/Downloads/MySQL-5.5/mysql-5.5.42-linux2.6-x86_64.tar.gz http://cdn.mysql.com/Downloads/MySQL-5.5/mysql-5.5.42-linux2.6-i686.tar.gz
MySQL5.6 http://cdn.mysql.com/Downloads/MySQL-5.6/mysql-5.6.23-linux-glibc2.5-i686.tar.gz http://cdn.mysql.com/Downloads/MySQL-5.6/mysql-5.6.23-linux-glibc2.5-x86_64.tar.gz
MySQL5.0以后的各历史归档版本 http://downloads.mysql.com/archives/community/