這篇文章給大家分享的是有關MySQL如何升級的內容。小編覺得挺實用的,因此分享給大家做個參考,一起跟隨小編過來看看吧。
成都創新互聯專業為企業提供長島網站建設、長島做網站、長島網站設計、長島網站制作等企業網站建設、網頁設計與制作、長島企業網站模板建站服務,10余年長島做網站經驗,不只是建網站,更提供有價值的思路和整體網絡服務。
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做升級,若升級失敗了怎么辦?
在做升級時,一般創建一個從庫進行升級,若升級失敗,也不會影響到主庫;若升級成功,測試也成功,便會將其他的從庫也逐漸升級到新版本,最后將主庫下線,提升一個從庫做新主庫,對舊主庫進行版本升級。
感謝各位的閱讀!關于“MySQL如何升級”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,讓大家可以學到更多知識,如果覺得文章不錯,可以把它分享出去讓更多的人看到吧!
當前標題:MySQL如何升級
文章出自:http://vcdvsql.cn/article36/gjissg.html
成都網站建設公司_創新互聯,為您提供App開發、企業網站制作、網站導航、做網站、網站營銷、動態網站
聲明:本網站發布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創新互聯