久久精品人人爽,华人av在线,亚洲性视频网站,欧美专区一二三

MySQL如何升級

144次閱讀
沒有評論

共計 1989 個字符,預計需要花費 5 分鐘才能閱讀完成。

自動寫代碼機器人,免費開通

這篇文章給大家分享的是有關 MySQL 如何升級的內容。丸趣 TV 小編覺得挺實用的,因此分享給大家做個參考,一起跟隨丸趣 TV 小編過來看看吧。

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 如何升級”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,讓大家可以學到更多知識,如果覺得文章不錯,可以把它分享出去讓更多的人看到吧!

向 AI 問一下細節

正文完
 
丸趣
版權聲明:本站原創文章,由 丸趣 2023-12-04發表,共計1989字。
轉載說明:除特殊說明外本站除技術相關以外文章皆由網絡搜集發布,轉載請注明出處。
評論(沒有評論)
主站蜘蛛池模板: 开远市| 九龙坡区| 柳江县| 时尚| 太仓市| 来宾市| 洞口县| 罗江县| 河池市| 微山县| 玉树县| 永泰县| 涞水县| 巫山县| 东乌珠穆沁旗| 灌阳县| 高阳县| 林甸县| 班戈县| 哈尔滨市| 黔西县| 出国| 盘锦市| 鄢陵县| 石林| 土默特左旗| 衡南县| 安丘市| 威海市| 瑞金市| 明溪县| 辽宁省| 龙胜| 湟源县| 叙永县| 溧阳市| 色达县| 黄冈市| 故城县| 佛冈县| 阿拉善盟|