English | 简体中文 | 繁體中文 | Русский язык | Français | Español | Português | Deutsch | 日本語 | 한국어 | Italiano | بالعربية
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 (при отправке письма, пожалуйста, замените # на @) для жалоб и предоставьте соответствующие доказательства. При обнаружении правонарушения, сайт немедленно удаляет涉嫌侵权的内容。