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