English | 简体中文 | 繁體中文 | Русский язык | Français | Español | Português | Deutsch | 日本語 | 한국어 | Italiano | بالعربية

Il miglior metodo per aggiornare MySQL

MySQL 5.7 ha aggiunto molte nuove funzionalità, come: DDL online, replica multi-sorgente, semi-sincronizzazione migliorata, trasmissione degli spazi di archiviazione, libreria sys, Group Replication, ecc. Finalmente ho avuto l'opportunità di aggiornare MySQL a 5.7, sono molto entusiasta.

panoramica dell'aggiornamento di MySQL

essenza dell'aggiornamento di MySQL:

l'aggiornamento del dizionario dei dati

il dizionario dei dati ha: mysql, information_schema, performance_schema, schema sys.

due modi di aggiornamento di MySQL:

aggiornamento in loco:

adatto all'aggiornamento di piccole versioni.

ovvero chiudere MySQL attuale, sostituire il file binario o il pacchetto attuale, riavviare MySQL sul directory dei dati esistente e eseguire mysql_upgrade.

caratteristiche: non modifica i file di dati, veloce nell'aggiornamento; ma, non può superare il sistema operativo, non può superare le grandi versioni (5.5—>5.7).

upgrade logico:

适合不同操作系统的MySQL升级,大版本之间的升级。

即:使用mysqldump 或 mydumper 导入导出数据,实现版本的升级。

特点:可以跨操作系统,跨大版本;但,升级速度慢,容易出现乱码等问题。

升级前的准备:

提前做好备份。

了解新版本变更的信息(哪些不再兼容,不再支持哪些功能)

在官方网站的general information—>what is new in mysql 5.7

升级的注意事项:

确认新版本是否有重大变更

注意 SQL mode 的变化

比如:在MySQL5.7中发生了SQL mode的变化,对不再支持的SQL mode,部分SQL会跑不通,此时可以清空SQL mode,跑完之后在设置SQL mode。

升级成功后,确认业务SQL是否可以跑通

程序层是否都正常

有时原使用的程序语言部分内容不被支持新版本数据库。比如,有一次在5.1时用的是PHP4.0,但升级到5.6,PHP的某些函数不被支持。

在升级完成之后,一定要在测试时使用和线上版本相同的程序,测试是否存在问题。

存储引擎的变化

比如:在未来的5.8版本,不再支持myisam 引擎。

注意字符集的乱码问题

接下来是,使用in-place upgrade方式,将MySQL5.6升级到MySQL5.7。

In-place upgrade 升级MySQL

环境:

5.6.15 —>5.7.20

升级前的准备:

备份+留意新版本的变更内容
升级操作:

1、对5.7的软件包,下载,解压

# tar -xzvf mysql-5.7.20-linux-glibc2.12-x86_64.tar.gz
# ln -s mysql-5.7.20-linux-glibc2.12-x86_64 mysql5.7

2、关闭当前MySQL(5.6)

# mysql -u root -p -S /data/mysql3308/mysql3308.sock --execute="SET GLOBAL innodb_fast_shutdown=0"
# mysqladmin -u root -p -S /data/mysql3308/mysql3308.sock shutdown

3、替换二进制文件(5.7 替换 5.6)

# cd /usr/local
# mv mysql mysql5.6
# mv mysql5.7 mysql

4, avvia MySQL utilizzando il directory dei dati esistente

# mysqld_safe --user=mysql --socket=/data/mysql3308/mysql3308.sock -p --skip-grant-tables --datadir=/data/mysql3308/data

5, controlla se tutte le tabelle sono compatibili con la versione corrente e aggiorna le librerie di sistema

# mysql_upgrade -uroot -p -S /data/mysql3308/mysql3308.sock
Nota: l'azione di mysql_upgrade è controllare se tutte le tabelle di tutti i database sono compatibili con la nuova versione corrente e aggiornare le librerie di sistema.

6, riavvia per assicurarsi che le modifiche apportate alle tabelle di sistema siano efficaci

# mysqld --defaults-file=/data/mysql3308/my3308.cnf &
# mysql -uroot -p -S /data/mysql3308/mysql3308.sock

Fino a questo punto, l'aggiornamento è stato completato.

Domanda: cosa fare se l'aggiornamento di MySQL fallisce?

Quando si esegue un aggiornamento, di solito si crea un database di backup per l'aggiornamento, se l'aggiornamento fallisce, non influenzerà il database principale; se l'aggiornamento ha successo e il test è riuscito, altri database di backup verranno gradualmente aggiornati alla nuova versione, infine il database principale verrà disattivato e un database di backup verrà promosso a nuovo database principale, e il database principale verrà aggiornato alla nuova versione.

Dichiarazione: il contenuto di questo articolo è stato tratto da Internet, il copyright spetta ai rispettivi autori, il contenuto è stato contribuito e caricato dagli utenti di Internet autonomamente, questo sito non detiene i diritti di proprietà, non è stato editato manualmente e non assume alcuna responsabilità legale. Se trovi contenuti sospetti di violazione del copyright, ti preghiamo di inviare una e-mail a: notice#oldtoolbag.com (al momento dell'invio dell'e-mail, sostituisci # con @) per segnalare il problema e fornire prove pertinenti. Una volta verificata, questo sito eliminerà immediatamente il contenuto sospetto di violazione del copyright.

Ti potrebbe interessare