實(shí)戰(zhàn)MySQL升級(jí)的最佳方法
MySQL5.7新增了不少新功能,比如:Online DDL、多源復(fù)制、增強(qiáng)半同步、表空間傳輸、sys 庫、Group Replication等。最近終于等到了一個(gè)機(jī)會(huì),將MySQL升級(jí)到5.7,很是興奮不已。
MySQL升級(jí)的概述
MySQL升級(jí)的實(shí)質(zhì):
對(duì)數(shù)據(jù)字典的升級(jí)
數(shù)據(jù)字典有:mysql、information_schema、performance_schema、sys schema。
MySQL升級(jí)的兩種方式:
in-place upgrade:
適合小版本的升級(jí)。
即 關(guān)閉當(dāng)前的MySQL,替換當(dāng)前的二進(jìn)制文件或包,在現(xiàn)有的數(shù)據(jù)目錄上重啟MySQL,并運(yùn)行mysql_upgrade.
特點(diǎn):不改變數(shù)據(jù)文件,升級(jí)速度快;但,不可以跨操作系統(tǒng),不可以跨大版本(5.5—>5.7).
logical upgrade:
適合不同操作系統(tǒng)的MySQL升級(jí),大版本之間的升級(jí)。
即:使用mysqldump 或 mydumper 導(dǎo)入導(dǎo)出數(shù)據(jù),實(shí)現(xiàn)版本的升級(jí)。
特點(diǎn):可以跨操作系統(tǒng),跨大版本;但,升級(jí)速度慢,容易出現(xiàn)亂碼等問題。
升級(jí)前的準(zhǔn)備:
提前做好備份。
了解新版本變更的信息(哪些不再兼容,不再支持哪些功能)
在官方網(wǎng)站的general information—>what is new in mysql 5.7
升級(jí)的注意事項(xiàng):
確認(rèn)新版本是否有重大變更
注意 SQL mode 的變化
比如:在MySQL5.7中發(fā)生了SQL mode的變化,對(duì)不再支持的SQL mode,部分SQL會(huì)跑不通,此時(shí)可以清空SQL mode,跑完之后在設(shè)置SQL mode。
升級(jí)成功后,確認(rèn)業(yè)務(wù)SQL是否可以跑通
程序?qū)邮欠穸颊?br />
有時(shí)原使用的程序語言部分內(nèi)容不被支持新版本數(shù)據(jù)庫。比如,有一次在5.1時(shí)用的是PHP4.0,但升級(jí)到5.6,PHP的某些函數(shù)不被支持。
在升級(jí)完成之后,一定要在測(cè)試時(shí)使用和線上版本相同的程序,測(cè)試是否存在問題。
存儲(chǔ)引擎的變化
比如:在未來的5.8版本,不再支持myisam 引擎。
注意字符集的亂碼問題
接下來是,使用in-place upgrade方式,將MySQL5.6升級(jí)到MySQL5.7。
In-place upgrade 升級(jí)MySQL
環(huán)境:
5.6.15 —>5.7.20
升級(jí)前的準(zhǔn)備:
備份+留意新版本的變更內(nèi)容
升級(jí)操作:
1、對(duì)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、關(guān)閉當(dāng)前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、替換二進(jìn)制文件(5.7 替換 5.6)
# cd /usr/local # mv mysql mysql5.6 # mv mysql5.7 mysql
4、使用現(xiàn)有的數(shù)據(jù)目錄啟動(dòng)MySQL
# mysqld_safe --user=mysql --socket=/data/mysql3308/mysql3308.sock -p --skip-grant-tables --datadir=/data/mysql3308/data
5、檢查所有表是否與當(dāng)前版本兼容,并更新系統(tǒng)庫
# mysql_upgrade -uroot -p -S /data/mysql3308/mysql3308.sock 注:mysql_upgrade的作用是檢查所有庫的所有表是否與當(dāng)前的新版本兼容,并更新系統(tǒng)庫。
6、重啟,確保對(duì)系統(tǒng)表所做的變更得以生效
# mysqld --defaults-file=/data/mysql3308/my3308.cnf & # mysql -uroot -p -S /data/mysql3308/mysql3308.sock
至此,升級(jí)完成。
問題:對(duì)MySQL做升級(jí),若升級(jí)失敗了怎么辦?
在做升級(jí)時(shí),一般創(chuàng)建一個(gè)從庫進(jìn)行升級(jí),若升級(jí)失敗,也不會(huì)影響到主庫;若升級(jí)成功,測(cè)試也成功,便會(huì)將其他的從庫也逐漸升級(jí)到新版本,最后將主庫下線,提升一個(gè)從庫做新主庫,對(duì)舊主庫進(jìn)行版本升級(jí)。
- MySQL 5.7.30 安裝與升級(jí)問題詳細(xì)教程
- Docker版的MySQL5.7升級(jí)到MySQL8.0.13,數(shù)據(jù)遷移
- phpstudy2018升級(jí)MySQL5.5為5.7教程(圖文)
- CentOS 7中升級(jí)MySQL 5.7.23的坑與解決方法
- 升級(jí)到MySQL5.7后開發(fā)不得不注意的一些坑
- phpStudy中升級(jí)MySQL版本到5.7.17的方法步驟
- Win下Mysql5.6升級(jí)到5.7的方法
- Windows(x86,64bit)升級(jí)MySQL 5.7.17免安裝版的詳細(xì)教程
- MySQL數(shù)據(jù)庫升級(jí)的一些"陷阱"
相關(guān)文章
mysql Community Server 5.7.19安裝指南(詳細(xì))
這篇文章主要介紹了mysql Community Server 5.7.19安裝指南(詳細(xì)),需要的朋友可以參考下2017-10-10一文帶你玩轉(zhuǎn)MySQL獲取時(shí)間和格式轉(zhuǎn)換各類操作方法詳解
最近在開發(fā)中常常使用時(shí)間的轉(zhuǎn)換函數(shù),所以一直都想整理一下這些函數(shù),下面這篇文章主要給大家介紹了關(guān)于MySQL獲取時(shí)間和格式轉(zhuǎn)換各類操作方法的相關(guān)資料,文中通過實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下2022-08-08MySQL MyISAM 優(yōu)化設(shè)置點(diǎn)滴
MyISAM類型的表強(qiáng)調(diào)的是性能,其執(zhí)行數(shù)度比InnoDB類型更快, 只是不提供事務(wù)支持.大部分項(xiàng)目是讀多寫少的項(xiàng)目,而Myisam的讀性能是比innodb強(qiáng)不少的2016-05-05MSQL中DATETIME或TIMESTAMP的區(qū)別小結(jié)
MySQL中的?DATETIME?和?TIMESTAMP?類型都用于存儲(chǔ)日期和時(shí)間信息,本文主要介紹了MSQL中DATETIME或TIMESTAMP的區(qū)別小結(jié),具有一定的參考價(jià)值,感興趣的可以了解一下2024-03-03Mysql查詢語句執(zhí)行過程及運(yùn)行原理分析
這篇文章主要介紹了Mysql查詢語句執(zhí)行過程及運(yùn)行原理分析,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-08-08