欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

實戰(zhàn)MySQL升級的最佳方法

 更新時間:2017年12月22日 09:47:33   作者:star_glm  
這篇文章給大家從理論到實戰(zhàn)詳細分享了MySQL升級的最佳方法,有需要的朋友跟著學習操作下吧。

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

MySQL升級的概述

MySQL升級的實質:

對數(shù)據(jù)字典的升級

數(shù)據(jù)字典有:mysql、information_schema、performance_schema、sys schema。

MySQL升級的兩種方式:

in-place upgrade:

適合小版本的升級。

即 關閉當前的MySQL,替換當前的二進制文件或包,在現(xiàn)有的數(shù)據(jù)目錄上重啟MySQL,并運行mysql_upgrade.

特點:不改變數(shù)據(jù)文件,升級速度快;但,不可以跨操作系統(tǒng),不可以跨大版本(5.5—>5.7).

logical upgrade:

適合不同操作系統(tǒng)的MySQL升級,大版本之間的升級。

即:使用mysqldump 或 mydumper 導入導出數(shù)據(jù),實現(xiàn)版本的升級。

特點:可以跨操作系統(tǒng),跨大版本;但,升級速度慢,容易出現(xiàn)亂碼等問題。

升級前的準備:

提前做好備份。

了解新版本變更的信息(哪些不再兼容,不再支持哪些功能)

在官方網(wǎng)站的general information—>what is new in mysql 5.7

升級的注意事項:

確認新版本是否有重大變更

注意 SQL mode 的變化

比如:在MySQL5.7中發(fā)生了SQL mode的變化,對不再支持的SQL mode,部分SQL會跑不通,此時可以清空SQL mode,跑完之后在設置SQL mode。

升級成功后,確認業(yè)務SQL是否可以跑通

程序層是否都正常

有時原使用的程序語言部分內容不被支持新版本數(shù)據(jù)庫。比如,有一次在5.1時用的是PHP4.0,但升級到5.6,PHP的某些函數(shù)不被支持。

在升級完成之后,一定要在測試時使用和線上版本相同的程序,測試是否存在問題。

存儲引擎的變化

比如:在未來的5.8版本,不再支持myisam 引擎。

注意字符集的亂碼問題

接下來是,使用in-place upgrade方式,將MySQL5.6升級到MySQL5.7。

In-place upgrade 升級MySQL

環(huán)境:

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、使用現(xiàn)有的數(shù)據(jù)目錄啟動MySQL

# mysqld_safe --user=mysql --socket=/data/mysql3308/mysql3308.sock -p --skip-grant-tables --datadir=/data/mysql3308/data

5、檢查所有表是否與當前版本兼容,并更新系統(tǒng)庫

# mysql_upgrade -uroot -p -S /data/mysql3308/mysql3308.sock
注:mysql_upgrade的作用是檢查所有庫的所有表是否與當前的新版本兼容,并更新系統(tǒng)庫。

6、重啟,確保對系統(tǒng)表所做的變更得以生效

# mysqld --defaults-file=/data/mysql3308/my3308.cnf &
# mysql -uroot -p -S /data/mysql3308/mysql3308.sock

至此,升級完成。

問題:對MySQL做升級,若升級失敗了怎么辦?

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

相關文章

  • mysql Community Server 5.7.19安裝指南(詳細)

    mysql Community Server 5.7.19安裝指南(詳細)

    這篇文章主要介紹了mysql Community Server 5.7.19安裝指南(詳細),需要的朋友可以參考下
    2017-10-10
  • 一文帶你玩轉MySQL獲取時間和格式轉換各類操作方法詳解

    一文帶你玩轉MySQL獲取時間和格式轉換各類操作方法詳解

    最近在開發(fā)中常常使用時間的轉換函數(shù),所以一直都想整理一下這些函數(shù),下面這篇文章主要給大家介紹了關于MySQL獲取時間和格式轉換各類操作方法的相關資料,文中通過實例代碼介紹的非常詳細,需要的朋友可以參考下
    2022-08-08
  • MySQL如何新建用戶并授權

    MySQL如何新建用戶并授權

    本文主要介紹了如何在MySQL中創(chuàng)建新用戶并管理其權限,包括增刪改查、創(chuàng)建表、刪除表等操作,文中詳細說明了MySQL 5.7.18和MySQL 8.0版本中的權限配置,以及如何根據(jù)需要添加或刪除權限的步驟,旨在提供實用的數(shù)據(jù)庫管理技巧
    2024-10-10
  • MySQL中的RAND()函數(shù)使用詳解

    MySQL中的RAND()函數(shù)使用詳解

    這篇文章主要介紹了MySQL中的RAND()函數(shù)使用詳解,是MySQL入門學習中的基礎知識,需要的朋友可以參考下
    2015-05-05
  • MySQL MyISAM 優(yōu)化設置點滴

    MySQL MyISAM 優(yōu)化設置點滴

    MyISAM類型的表強調的是性能,其執(zhí)行數(shù)度比InnoDB類型更快, 只是不提供事務支持.大部分項目是讀多寫少的項目,而Myisam的讀性能是比innodb強不少的
    2016-05-05
  • 深入解析MySQL?事務

    深入解析MySQL?事務

    這篇文章主要給大家分享的是mysql事務解析,事務(transaction)是業(yè)務邏輯的一個基本的單元組成,下面文章圍繞mysql事務的相關資料展開詳細內容,需要的朋友可以參考一下希望對大家有所幫助
    2022-01-01
  • MSQL中DATETIME或TIMESTAMP的區(qū)別小結

    MSQL中DATETIME或TIMESTAMP的區(qū)別小結

    MySQL中的?DATETIME?和?TIMESTAMP?類型都用于存儲日期和時間信息,本文主要介紹了MSQL中DATETIME或TIMESTAMP的區(qū)別小結,具有一定的參考價值,感興趣的可以了解一下
    2024-03-03
  • MYSQL清空表和截斷表問題

    MYSQL清空表和截斷表問題

    這篇文章主要介紹了MYSQL清空表和截斷表問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-03-03
  • 解析mysql與Oracle update的區(qū)別

    解析mysql與Oracle update的區(qū)別

    本篇文章是對mysql與Oracle update的區(qū)別進行了詳細的分析介紹,需要的朋友參考下
    2013-07-07
  • Mysql查詢語句執(zhí)行過程及運行原理分析

    Mysql查詢語句執(zhí)行過程及運行原理分析

    這篇文章主要介紹了Mysql查詢語句執(zhí)行過程及運行原理分析,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2023-08-08

最新評論