<form id="hz9zz"></form>
  • <form id="hz9zz"></form>

      <nobr id="hz9zz"></nobr>

      <form id="hz9zz"></form>

    1. 明輝手游網中心:是一個免費提供流行視頻軟件教程、在線學習分享的學習平臺!

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

      [摘要]MySQL5.7新增了不少新功能,比如:Online DDL、多源復制、增強半同步、表空間傳輸、sys 庫、Group Replication等。最近終于等到了一個機會,將MySQL升級到5.7,很...

      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中文網其它相關文章!


      學習教程快速掌握從入門到精通的SQL知識。




      日韩精品一区二区三区高清