濮阳杆衣贸易有限公司

主頁 > 知識庫 > 實(shí)戰(zhàn)MySQL升級的最佳方法

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

熱門標(biāo)簽:西安400電話在哪里辦理 凱立德科技館地圖標(biāo)注 甘孜電話機(jī)器人廠家 上海智能外呼系統(tǒng)需要多少錢 電銷機(jī)器人好品牌門薩維l 中科嘉智人工智能電銷機(jī)器人 哈爾濱crm外呼系統(tǒng)價(jià)格 銀川電銷外呼系統(tǒng)定制 做地圖標(biāo)注都需要什么工具

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

MySQL升級的概述

MySQL升級的實(shí)質(zhì):

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

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

MySQL升級的兩種方式:

in-place upgrade:

適合小版本的升級。

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

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

logical upgrade:

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

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

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

升級前的準(zhǔn)備:

提前做好備份。

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

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

升級的注意事項(xiàng):

確認(rèn)新版本是否有重大變更

注意 SQL mode 的變化

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

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

程序?qū)邮欠穸颊?br />

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

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

存儲引擎的變化

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

注意字符集的亂碼問題

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

In-place upgrade 升級MySQL

環(huán)境:

5.6.15 —>5.7.20

升級前的準(zhǔn)備:

備份+留意新版本的變更內(nèi)容
升級操作:

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、關(guān)閉當(dāng)前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、替換二進(jìn)制文件(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、檢查所有表是否與當(dāng)前版本兼容,并更新系統(tǒng)庫

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

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

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

至此,升級完成。

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

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

您可能感興趣的文章:
  • MySQL 5.7.30 安裝與升級問題詳細(xì)教程
  • Docker版的MySQL5.7升級到MySQL8.0.13,數(shù)據(jù)遷移
  • phpstudy2018升級MySQL5.5為5.7教程(圖文)
  • CentOS 7中升級MySQL 5.7.23的坑與解決方法
  • 升級到MySQL5.7后開發(fā)不得不注意的一些坑
  • phpStudy中升級MySQL版本到5.7.17的方法步驟
  • Win下Mysql5.6升級到5.7的方法
  • Windows(x86,64bit)升級MySQL 5.7.17免安裝版的詳細(xì)教程
  • MySQL數(shù)據(jù)庫升級的一些"陷阱"

標(biāo)簽:那曲 安康 平頂山 山南 浙江 安徽 濮陽 四川

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《實(shí)戰(zhàn)MySQL升級的最佳方法》,本文關(guān)鍵詞  實(shí)戰(zhàn),MySQL,升級,的,最佳,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《實(shí)戰(zhàn)MySQL升級的最佳方法》相關(guān)的同類信息!
  • 本頁收集關(guān)于實(shí)戰(zhàn)MySQL升級的最佳方法的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    务川| 贡山| 漳浦县| 昆明市| 敦煌市| 水城县| 收藏| 西宁市| 平山县| 嘉善县| 定襄县| 陇川县| 新泰市| 武乡县| 徐州市| 同仁县| 南木林县| 山东省| 易门县| 濉溪县| 汉沽区| 德兴市| 东宁县| 吉首市| 南乐县| 大关县| 芜湖县| 大石桥市| 嘉黎县| 林西县| 于都县| 九江市| 广西| 蒙山县| 晋江市| 连州市| 沾化县| 龙南县| 金平| 西乌珠穆沁旗| 衡水市|