首頁 >資料庫 >mysql教程 >MySQL升級的最佳方法實例分享

MySQL升級的最佳方法實例分享

小云云
小云云原創
2018-01-05 17:39:571713瀏覽

MySQL5.7新增了不少新功能,例如:Online DDL、多重來源複製、增強半同步、表空間傳輸、sys 函式庫、Group Replication等。最近終於等到了一個機會,將MySQL升級到5.7,很是興奮不已。本文主要給大家從理論到實戰詳細分享了MySQL升級的最佳方法,有需要的朋友跟著學習操作下。

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做升級,若升級失敗了怎麼辦?

在做升級時,一般創建一個從庫進行升級,若升級失敗,也不會影響到主庫;若升級成功,測試也成功,便會將其他的從庫也逐漸升級到新版本,最後將主庫下線,提升一個從庫做新主庫,對舊主庫進行版本升級。

相關推薦:

mysql升級後無法啟動的解決方法

#詳解php封裝Mysql操作類別

PHP如何解決MySQL儲存資料中文亂碼

以上是MySQL升級的最佳方法實例分享的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn