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

Лучший способ обновления MySQL

MySQL 5.7 добавил много новых функций, например: Online DDL, многоисточниковая репликация, улучшенная полусинхронизация, передача разделов, библиотека sys, Group Replication и т.д. Наконец-то дождались возможности обновить MySQL до версии 5.7, очень рады.

Обзор обновления MySQL

Суть обновления MySQL:

Обновление словаря данных

Словарь данных включает: mysql, information_schema, performance_schema, sys schema.

Два способа обновления MySQL:

обновление на месте:

Подходит для обновления малых версий.

Это означает: отключить текущий MySQL, заменить текущий двоичный файл или пакет, перезапустить MySQL в существующей директории данных и запустить mysql_upgrade.

特点是:не изменяет файлы данных, быстрый процесс обновления; но, не может переходить через операционные системы, не может переходить через большие версии (5.5—>5.7).

логическое обновление:

适合不同操作系统的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. Запустите MySQL с существующей директорией данных

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

5. Проверьте, соответствуют ли все таблицы текущей версии, и обновите системные библиотеки

# mysql_upgrade -uroot -p -S /data/mysql3308/mysql3308.sock
Примечание: mysql_upgrade выполняет проверку всех таблиц всех библиотек на соответствие текущей версии и обновляет системные библиотеки.

6. Перезагрузите, чтобы убедиться, что изменения в системных таблицах вступили в силу

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

Таким образом, обновление завершено.

Вопрос: Что делать, если обновление MySQL失败了?

При обновлении, обычно создается библиотека для обновления, если обновление失败ло, это не повлияет на основную библиотеку; если обновление успешно, тест также успешен, другие библиотеки будут постепенно обновлены до новой версии, в конце концов, основная библиотека будет снята с эксплуатации, и одна из библиотек будет обновлена до новой основной библиотеки, и старая основная библиотека будет обновлена до новой версии.

Заявление: контент этой статьи взят из Интернета, авторские права принадлежат соответствующему автору. Контент предоставлен пользователями Интернета в порядке добровольного сотрудничества и загрузки. Этот сайт не имеет права собственности на него, не делает ручной редакции и не несет ответственности за связанные с этим法律责任. Если вы обнаружите контент,涉嫌侵犯版权, пожалуйста, отправьте письмо по адресу: notice#oldtoolbag.com (при отправке письма, пожалуйста, замените # на @) для жалоб и предоставьте соответствующие доказательства. При обнаружении правонарушения, сайт немедленно удаляет涉嫌侵权的内容。

Рекомендуем также