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
公升級前的準備:
備份+留意新版本的變更內容
公升級操作:
# 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公升級的最佳方法
mysql5.7新增了不少新功能,比如 online ddl 多源複製 增強半同步 表空間傳輸 sys 庫 group replication等。最近終於等到了乙個機會,將mysql公升級到5.7,很是興奮不已。mysql公升級的概述 mysql公升級的實質 對資料字典的公升級 資料字典有 mysq...
MySQL各版本公升級最佳實踐
一 公升級前注意事項在開始之前,你要意識到這是乙個很慎重的操作,將一步跨過乙個重要的mysql版本。也就是說,這是有風險的。用二進位制檔案公升級是不建議的,而且這樣直接跨越乙個重要版本也是不安全的,所以你絕不能這樣5.0 5.5,5.1 5.6,或者5.0 5.6做。有乙個問題是,mysql版本不是...
phpstudy公升級Mysql的方法
phpstudy很糟心,不能選擇mysql的版本,所以就強制公升級。選擇好適合自己的配置後按download 1,使用有管理員許可權的cmd開啟phpstudy目錄下的mysql目錄下的bin資料夾,我的是d phpstudy phptutorial mysql bin 執行 mysqld remo...