【經驗】記錄一次MySQL升級的運維實踐
前言
MySQL5.7新增了不少新功能,比如:Online DDL、多源複製、增強半同步、表空間傳輸、sys 庫、Group Replication等。最近終於等到了一個機會,將MySQL升級到5.7,很是興奮不已,嘻嘻。
MySQL升級的概述
MySQL升級的實質:
- 對資料字典的升級
- 資料字典有:mysql、information_schema、performance_schema、sys schema。
MySQL升級的兩種方式:
-
in-place upgrade:
- 適合小版本的升級。
- 即 關閉當前的MySQL,替換當前的二進位制檔案或包,在現有的資料目錄上重啟MySQL,並執行mysql_upgrade.
- 特點:不改變資料檔案,升級速度快;但,不可以跨作業系統,不可以跨大版本(5.5—>5.7).
-
logical upgrade:
- 適合不同作業系統的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做升級,若升級失敗了怎麼辦?
- 在做升級時,一般建立一個從庫進行升級,若升級失敗,也不會影響到主庫;若升級成功,測試也成功,便會將其他的從庫也逐漸升級到新版本,最後將主庫下線,提升一個從庫做新主庫,對舊主庫進行版本升級。
相關文章
- Redis 運維實際經驗紀錄之一Redis運維
- MySQL 升級的最佳實踐MySql
- 運維經理的運維經驗總結運維
- 記一次mysql小版本升級MySql
- 技術實踐丨GaussDB(DWS)運維管理功能“升級”的原理和使用運維
- 實踐案例:同程藝龍網的 Dubbo 升級經驗總結
- hadoop運維經驗Hadoop運維
- 極光筆記|百億級KV儲存在極光的運維實踐之路筆記運維
- 運維工程師打怪升級必經之路 V1.0.1運維工程師
- 運維人員的職業升級道路運維
- Tumblr的PHP 7升級經驗分享PHP
- 運維初級實踐——Linux系統命令教程運維Linux
- SEO 經驗記錄
- 記一次版本升級遇到的坑
- 遠端IT運維的升級,“團隊協作”運維
- 投稿007期|記一次基於vue的spa多頁籤實踐經驗Vue
- mysql load 相關實驗記錄MySql
- 記錄第一次完整的uni-app開發經驗APP
- openssl版本升級操作記錄
- AIX系統升級記錄AI
- redhat 6.5 mysql 升級5.5.48經mysql 5.6.32至mysql 5.7.16實施概略RedhatMySql
- 記一次macOS Mojave升級GCCMacGC
- oracle實驗記錄 (恢復-rman維護(1))Oracle
- oracle實驗記錄 (恢復-rman維護(2))Oracle
- 記錄一次WhatTheFuck經歷
- 記錄一次微信分享的經歷
- 真實記錄我的學習linux的經驗Linux
- RabbitMQ叢集運維實踐MQ運維
- 【實驗】【MySQL】MySQL中的運算子展示MySql
- MySQL從庫維護經驗分享MySql
- 升級Webpack5實踐Web
- 管理經驗分享會議記錄--【管理經驗】
- Liunx常用運維命令整理記錄運維
- 升級MySQL8.0的歷險記MySql
- UIScrollView 實踐經驗UIView
- vue-cli3.0 升級記錄Vue
- centos下升級git版本的操作記錄CentOSGit
- mysql的升級MySql