一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務(wù)器之家:專注于服務(wù)器技術(shù)及軟件下載分享
分類導(dǎo)航

Mysql|Sql Server|Oracle|Redis|MongoDB|PostgreSQL|Sqlite|DB2|mariadb|Access|數(shù)據(jù)庫(kù)技術(shù)|

服務(wù)器之家 - 數(shù)據(jù)庫(kù) - Mysql - 實(shí)戰(zhàn)MySQL升級(jí)的最佳方法

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

2020-08-23 17:16star_glm Mysql

這篇文章給大家從理論到實(shí)戰(zhàn)詳細(xì)分享了MySQL升級(jí)的最佳方法,有需要的朋友跟著學(xué)習(xí)操作下吧。

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

MySQL升級(jí)的概述

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

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

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

MySQL升級(jí)的兩種方式:

in-place upgrade:

適合小版本的升級(jí)。

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

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

logical upgrade:

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

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

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

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

提前做好備份。

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

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

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

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

注意 SQL mode 的變化

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

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

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

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

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

存儲(chǔ)引擎的變化

比如:在未來(lái)的5.8版本,不再支持myisam 引擎。

注意字符集的亂碼問(wèn)題

接下來(lái)是,使用in-place upgrade方式,將MySQL5.6升級(jí)到MySQL5.7。

In-place upgrade 升級(jí)MySQL

環(huán)境:

5.6.15 —>5.7.20

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

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

1、對(duì)5.7的軟件包,下載,解壓

?
1
2
# 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)

?
1
2
# 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)

?
1
2
3
# cd /usr/local
# mv mysql  mysql5.6
# mv mysql5.7 mysql

4、使用現(xiàn)有的數(shù)據(jù)目錄啟動(dòng)MySQL

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

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

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

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

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

至此,升級(jí)完成。

問(wèn)題:對(duì)MySQL做升級(jí),若升級(jí)失敗了怎么辦?

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

原文鏈接:https://my.oschina.net/starglm/blog/1588055

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 韩国最新三级网站在线播放 | 亚洲精品国产乱码AV在线观看 | 国产精品永久免费视频观看 | 日本三级s级在线播放 | 国产精品久久久久久久久久久久 | 任我鲁精品视频精品 | 色婷婷天天综合在线 | 毛片视频在线免费观看 | 好大好粗好舒服 | 大ji巴好好爽好深网站 | 暖暖日本高清 | 风间由美一区二区av101 | 韩国最新理论片奇忧影院 | 免费特黄一区二区三区视频一 | 三体动漫在线观看免费完整版2022 | 久久国产影院 | 喜欢老头吃我奶躁我的动图 | ysl蜜桃色成人麻豆 youwu在线影院 | 四虎免费影院在线播放 | 99精品在线 | 青青青手机视频在线观看 | 日韩免费视频播放 | 国产免费精彩视频 | 幻女free性摘花第一次 | 国内精品在线观看视频 | 精品国产成人 | 白发在线视频播放观看免费 | 亚州日韩精品AV片无码中文 | 国产1区二区 | 九九国产在线观看 | 双性np玩烂了np欲之国的太子 | 国产精品毛片高清在线完整版 | bnb99八度免费影院 | 99影视在线视频免费观看 | 校园肉文高h | 亚洲高清一区二区三区四区 | 国产精品毛片久久久久久久 | 国产在线成人a | www一级片| 2020年国产精品午夜福利在线观看 | 国产香蕉一区二区精品视频 |