自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

不同場(chǎng)景分析:MySQL 升級(jí)的最佳實(shí)踐

數(shù)據(jù)庫(kù) MySQL 數(shù)據(jù)庫(kù)運(yùn)維
為什么MySQL升級(jí)是必須的? 原因有很多,比如:為了使用新增的特性,基于性能方面的考量, 修復(fù)的bug. 但是在沒(méi)有充分的測(cè)試以前就應(yīng)用到你的應(yīng)用中是非常危險(xiǎn)的, 因?yàn)樯?jí)可以能會(huì)讓你的應(yīng)用不能正常運(yùn)作- 也可能引起性能的問(wèn)題. 此外, 我建議你關(guān)注MySQL的發(fā)布信息和Percona Server - 看看最近的版本有什么變化。

MySQL升級(jí)是非常必要的. 我們?cè)?a rel="nofollow" target="_blank">Percona Support上列出了關(guān)于MySQL升級(jí)***實(shí)踐的各種問(wèn)題.這篇文章推薦了一些不同情況下升級(jí)MySQL的方法.

為什么MySQL升級(jí)是必須的? 原因有很多,比如:為了使用新增的特性,基于性能方面的考量, 修復(fù)的bug. 但是在沒(méi)有充分的測(cè)試以前就應(yīng)用到你的應(yīng)用中是非常危險(xiǎn)的, 因?yàn)樯?jí)可以能會(huì)讓你的應(yīng)用不能正常運(yùn)作- 也可能引起性能的問(wèn)題. 此外, 我建議你關(guān)注MySQL的發(fā)布信息和Percona Server - 看看最近的版本有什么變化. 也許在在***的版本中已修復(fù)了某個(gè)你正在煩惱的問(wèn)題.

通過(guò)SQL Dump升級(jí)主版本:

把Percona Server從5.1升級(jí)到5.5版本或者是從5.5升級(jí)到5.6版本的升級(jí)模式同樣適用于Oracle MySQL.

首先, 主版本升級(jí)并不是說(shuō)可以不做任何準(zhǔn)備,或者沒(méi)有任何風(fēng)險(xiǎn). 在升級(jí)之前你需要閱讀相關(guān)的“升級(jí)”文檔,比如:MySQL5.1到MySQL5.5的升級(jí)文檔,MySQL5.5到MySQL5.6的升級(jí)文檔.在這些文檔里面你需要特別注意“Incompatible Change”部分,并檢查你是否會(huì)受到這些變化的影響.它們可能是配置參數(shù)名字變更, 去掉舊的參數(shù),引入新的參數(shù)等- 你需要根據(jù)這些變化在my.cnf文件做相應(yīng)的變更.Percona Server 5.5需要特別注意的文檔在這里, Percona Server 5.6需要特別注意的文檔在這里.

現(xiàn)在,你有幾種可行的方式升級(jí),其中一種較靈活,另一種則依賴(lài)你當(dāng)前系統(tǒng)的拓?fù)浣Y(jié)構(gòu)和數(shù)據(jù)庫(kù)數(shù)據(jù)大小 - 這種方法比前一種更安全。我們看個(gè)例子從 Percona Server 5.5 升級(jí)到 Percona Server 5.6,來(lái)具體看一下彼此的升級(jí)過(guò)程。

通常情況下,有兩中升級(jí)方式:

  • 直接升級(jí):安裝好新版本數(shù)據(jù)庫(kù)后,利用已經(jīng)存在的數(shù)據(jù)文件夾,同時(shí)運(yùn)行mysql_upgrade腳本來(lái)升級(jí)。

  • SQL 導(dǎo)出: 從一個(gè)較老版本的mysql把數(shù)據(jù)導(dǎo)出,然后恢復(fù)到新版本的數(shù)據(jù)庫(kù)中。(利用mysqldump工具)。

相比之下,第二種方式更安全些,但是這也會(huì)使得升級(jí)的過(guò)程要慢一些。

理論上講,最安全的方式是:

  • 導(dǎo)出所有用戶(hù)的權(quán)限

  • 導(dǎo)出所有數(shù)據(jù)并恢復(fù)到新版本數(shù)據(jù)庫(kù)中

  • 恢復(fù)用戶(hù)權(quán)限到新數(shù)據(jù)庫(kù)中

下面是基本的操作步驟(在開(kāi)始之前***停止有關(guān)數(shù)據(jù)庫(kù)操作的應(yīng)用).

1) 獲取用戶(hù)和權(quán)限信息. 該操作會(huì)備份所有用戶(hù)的權(quán)限.

  1. $ wget percona.com/get/pt-show-grants;  
  2. $ perl pt-show-grants --user=root --ask-pass --flush > /root/grants.sql 

2) dump 5.5數(shù)據(jù)庫(kù)實(shí)例的所有信息(除去mysql, information_schema 和performance_schema數(shù)據(jù)庫(kù)).

  1. $ mysql -BNe "SELECT SCHEMA_NAME FROM INFORMATION_SCHEMA.SCHEMATA WHERE SCHEMA_NAME NOT IN ('mysql', 'performance_schema', 'information_schema')" | tr 'n' ' ' > /root/dbs-to-dump.sql  
  2. $ mysqldump --routines --events --single-transaction --databases $(cat /root/dbs-to-dump.sql) > /root/full-data-dump.sql 

3) 停止數(shù)據(jù)庫(kù)

  1. $ service mysql stop  
  2. or 
  3. $ /etc/init.d/mysql stop 

4) 移動(dòng)舊數(shù)據(jù)庫(kù)(5.5版本)的數(shù)據(jù)目錄(假設(shè)是/var/lib/mysql,此處應(yīng)該改為你自己的數(shù)據(jù)目錄)

  1. $ mv /var/lib/mysql/ /var/lib/mysql-55 

5) 安裝5.6版本(按照正常安裝流程). 如果你不是用的yum/apt-get方式安裝的,你需要執(zhí)行 mysql_install_db 和mysql_upgrade兩個(gè)命令.

6) 將在1)操作中導(dǎo)出的用戶(hù)信息導(dǎo)入到新數(shù)據(jù)庫(kù)中.

  1. mysql -uroot < /root/grants.sql 

7) 將2)導(dǎo)出的數(shù)據(jù)導(dǎo)入到新數(shù)據(jù)庫(kù).

  1. $ mysql -e "SET GLOBAL max_allowed_packet=1024*1024*1024";  
  2. $ mysql -uroot -p --max-allowed-packet=1G < /root/full-data-dump.sql; 

此時(shí), 所有的表都在MySQL 5.6中重建及重新加載完成,所以所有的二進(jìn)制文件對(duì)MySQL 5.6可用. 同時(shí)也你完成了最干凈/最穩(wěn)定的升級(jí)過(guò)程,你可以恢復(fù)你的應(yīng)用- 這個(gè)升級(jí)過(guò)程和valina MySQL與Percona Server的升級(jí)過(guò)程是一樣的.甚至你可以把Oracle MySQL升級(jí)到Percona Server. 比如: 把Oracle MySQL 5.5升級(jí)到Percona Server 5.6. 再次強(qiáng)調(diào): MySQL的升級(jí)過(guò)程和Percona Server的升級(jí)過(guò)程是一樣的,只需要將Percona Server 替換成Oracle MySQL即可.

"SQL dump" 也可以稱(chēng)為邏輯備份.用升級(jí)后的MySQL二進(jìn)制文件來(lái)重建所有的表基本沒(méi)有兼容問(wèn)題,從這一方面來(lái)說(shuō)"SQL dump"更安全. 但是對(duì)于TB, GB級(jí)的大數(shù)據(jù)來(lái)說(shuō),這種方法非常的耗時(shí). 另一方面, 備份/重新加載如此大的數(shù)據(jù)集,比如重建InnoDB表,你需要恢復(fù)很多的空閑磁盤(pán),這樣會(huì)引起的磁盤(pán)碎片整理優(yōu)化.對(duì)于常更新或者刪除的數(shù)據(jù)來(lái)說(shuō), 這么做是有益的.

用In-Place升級(jí)小版本:

這種升級(jí)方式是在一個(gè)主版本內(nèi)做小版本升級(jí), 比如把MySQL 5.5.35升級(jí)到MySQL 5.5.38或者是把Percona Server 5.6.14升級(jí)到***的Percona Server 5.6.20

這被稱(chēng)為一個(gè)就地升級(jí),你只安裝一個(gè)新的二進(jìn)制包,然后運(yùn)行mysql_upgrade腳本,如果必要的話,檢查和更新系統(tǒng)表。仍然,就地升級(jí)我們強(qiáng)烈推薦檢查新功能的發(fā)布說(shuō)明,bug修復(fù)等。Percona Server 5.5 和 Percona Server 5.6 發(fā)行說(shuō)明可以分別在這兒和那兒找到。

當(dāng)我們需要升級(jí)Percona服務(wù)器時(shí),針對(duì)它的Percona-specific的一些特性,對(duì)于Percona服務(wù)器我們有額外的文檔描述一些細(xì)節(jié),可以在這兒和那兒找到。這也包括完成就地升級(jí)過(guò)程的和yum/apt的包管理器。
 

同時(shí),在安全方面你可以升級(jí)那些使用較早描述的邏輯轉(zhuǎn)儲(chǔ)程序,mysqldump或mydumper程序——前者并行備份和恢復(fù)和邏輯備份,升級(jí)是最安全的方法。

直接升級(jí)到***版本:

跳過(guò)5.1版本直接把MySQL從5.0版本升級(jí)到5.5版本,或者跳過(guò)5.5版本直接從MySQL 5.1升級(jí)到5.6.甚至,可以直接從MySQL 5.0升級(jí)到MySQL 5.6雖然現(xiàn)在只有少數(shù)人還在使用MySQL 5.0版本. 這種同樣使用于Percona Server.

在這里我們假設(shè)跳過(guò)5.5版本,把Oracle MySQL或者Percona Server直接從5.1版本升級(jí)到5.6版本。

在開(kāi)始之前,你要意識(shí)到這是一個(gè)很慎重的操作,將一步跨過(guò)一個(gè)重要的MySQL版本。也就是說(shuō),這是有風(fēng)險(xiǎn)的。用二進(jìn)制文件升級(jí)是不建議的,而且這樣直接跨越一個(gè)重要版本也是不安全的,所以你絕不能這樣5.0->5.5,5.1->5.6,或者5.0->5.6做。有一個(gè)問(wèn)題是,MySQL版本不是所有改變都前向兼容的。新版本中介紹的一些改變可能不僅會(huì)影響數(shù)據(jù)如何處理,還會(huì)影響服務(wù)器行為包括SQL語(yǔ)句和MySQL服務(wù)器和內(nèi)部存儲(chǔ)引擎(此處不知標(biāo)準(zhǔn)否)。另一個(gè)問(wèn)題是MySQL5.0與5.6版本之間的變化,一些默認(rèn)的設(shè)置變量被改變了,這可能會(huì)導(dǎo)致結(jié)果完全不一樣或者行為完全不同。例如:MySQL5.5的默認(rèn)存儲(chǔ)引擎是InnoDB,MySQL5.6的存儲(chǔ)引擎InnoDB將可以為每個(gè)數(shù)據(jù)庫(kù)表創(chuàng)建單獨(dú)表空間(separate tablespace),還有GTID復(fù)制(GTID replication)也被引入。有太多細(xì)節(jié)這里就不一一列舉了,所有這些改變都被描述在MySQL的“升級(jí)文檔”中,詳情可以查看升級(jí)文檔。

這里重點(diǎn)提一下,極不推薦跳過(guò)一個(gè)重要版本來(lái)升級(jí)。從MySQL5.1升級(jí)到5.6不應(yīng)該一步完成,我建議先從5.1升級(jí)到5.5,再?gòu)?.5升級(jí)到5.6,每步都要運(yùn)行MySQL自動(dòng)升級(jí)(mysql_upgrade)。這將比較有效處理手冊(cè)上所說(shuō)的升級(jí)改變。

MySQL的升級(jí)預(yù)防措施:

MySQL的升級(jí)預(yù)防措施是升級(jí)的一個(gè)基本部分。在你升級(jí)之前,確保你在新的MySQL版本中徹底測(cè)試了所有的應(yīng)用功能。這對(duì)重要版本之間的升級(jí)尤為重要,對(duì)重要版本之間的跨越升級(jí)也很重要(例如,從MySQL5.1升級(jí)到MySQL5.6)。

確保你認(rèn)真閱讀了發(fā)行說(shuō)明,并且你清楚所有改變。你可以從以下鏈接中獲取Oracle MySQL 5.5和5.6的發(fā)行說(shuō)明:

http://dev.mysql.com/doc/relnotes/mysql/5.5/en/

http://dev.mysql.com/doc/relnotes/mysql/5.6/en/

Percona Server有單獨(dú)的發(fā)行說(shuō)明,按上面說(shuō)的順序可以參看以下鏈接:

http://www.percona.com/doc/percona-server/5.5/release-notes/release-notes_index.html
http://www.percona.com/doc/percona-server/5.6/release-notes/release-notes_index.html

如果你計(jì)劃升級(jí)到 Oracle MySQL 5.6 或者 Percona Server 5.6,我建議你首先檢查以下已經(jīng)存在的關(guān)鍵bugs。以下是你需要注意的一些bugs:

http://bugs.mysql.com/bug.php?id=66546
http://bugs.mysql.com/bug.php?id=68953
http://bugs.mysql.com/bug.php?id=69444
http://bugs.mysql.com/bug.php?id=70922
http://bugs.mysql.com/bug.php?id=72794
http://bugs.mysql.com/bug.php?id=73820

升級(jí)的層次結(jié)構(gòu):

這也是每一次MySQL升級(jí)的關(guān)鍵。你需要根據(jù)一個(gè)升級(jí)層次結(jié)構(gòu)來(lái)做你的每次升級(jí)。建議的次序結(jié)構(gòu)是:首先升級(jí) dev/QA servers,然后升級(jí) staging server,***升級(jí)到 production servers上。實(shí)際上,你可以縮小升級(jí)的步伐,一步一步升級(jí)到你想要的版本,每步都可以充分地測(cè)試原來(lái)的應(yīng)用。

一旦你對(duì)在test servers, staging servers等上運(yùn)行的升級(jí)感到滿意后,你就可以在你的production servers上進(jìn)行升級(jí)了。在副本環(huán)境下,我建議你先升級(jí)MySQL slaves(一個(gè)接一個(gè)的)***升級(jí)MySQL master。實(shí)際上,你可以先升級(jí)一個(gè)slaves,讓它在安全環(huán)境下運(yùn)行幾天,同時(shí)觀察仔細(xì)觀察它的運(yùn)行情況。如果你的服務(wù)器中沒(méi)有副本環(huán)境的設(shè)置,那么還是值得建立一個(gè)副本環(huán)境來(lái)測(cè)試新版的MySQL的。一旦你對(duì)升級(jí)結(jié)果感到滿意,你可以升級(jí)其他的slaves,***升級(jí)master。

Percona軟件包幫助你MySQL升級(jí):

在MySQL升級(jí)中,Percona Toolkit 都能幫助你。Percona Toolkit 的一些工具將會(huì)起到很大的作用。

pt-upgrade 是其中的一個(gè)工具。它使你能測(cè)試新版MySQL實(shí)例是否能夠達(dá)到像老版本處理一些特定查詢(xún)的時(shí)候一樣的速度。新版本可能有一些本質(zhì)上的改變,因?yàn)镸ySQL的查詢(xún)優(yōu)化器從5.1到5.6已經(jīng)有了重大改變,還有數(shù)據(jù)統(tǒng)計(jì)可能刷新,因此查詢(xún)計(jì)劃會(huì)改變。你可以在手冊(cè)中看到更多優(yōu)化器的改變。

pt-query-digest 是另一個(gè)能給你極大幫助的工具。你可以多次運(yùn)行你的slow query log,以比較確認(rèn)在現(xiàn)在的版本和新版本之間的表現(xiàn)差別。

你也可以從MySQL的Percona Cloud Tools中獲得幫助,這是一個(gè)托管服務(wù),可以為所有MySQL的使用提供查詢(xún)性能分析?,F(xiàn)在你可以免費(fèi)注冊(cè)這個(gè)服務(wù),因?yàn)楝F(xiàn)在這項(xiàng)服務(wù)在進(jìn)行公開(kāi)測(cè)試。Percona Cloud Tools在許多同類(lèi)產(chǎn)品中,能讓你可視化的觀察到每次MySQL升級(jí)后的查詢(xún)表現(xiàn)。

再次重申,強(qiáng)烈建議你每次更新MySQL前備份數(shù)據(jù)。Percona XtraBackup就是一款免費(fèi)、開(kāi)源的(就像所有Percona軟件一樣)。這是一個(gè)熱備份工具,它允許你在線備份數(shù)據(jù)而不影響你對(duì)數(shù)據(jù)庫(kù)的讀寫(xiě)操作,而且它備份數(shù)據(jù)時(shí)產(chǎn)生很小的影響。

***,你會(huì)覺(jué)得這個(gè)帖子也是很有用的”Upgrading MySQL.“雖然已經(jīng)是老帖子了,但是還是比較有意義的。再看一個(gè)有意義的文章webinar,”Upgrading to MySQL 5.6: Best Practices.“。這兩篇文都出自Percona CEO Peter Zaitsev

結(jié)論:

一次MySQL升級(jí)看起來(lái)是個(gè)簡(jiǎn)單的任務(wù),但實(shí)際上并沒(méi)有那么簡(jiǎn)單。我試圖在這篇文章中***限度覆蓋所有有關(guān)MySQL升級(jí)中你可能遇到的情況。再次強(qiáng)調(diào),我建議你在應(yīng)用更新的版本之前,先測(cè)試一下你的應(yīng)用在新版本中的效果。否則,可能會(huì)使你的應(yīng)用崩潰,或者得到的不是提高查詢(xún)效率而是降低查詢(xún)效率。***,我建議你準(zhǔn)備一個(gè)降級(jí)計(jì)劃或措施,以防你升級(jí)之后出現(xiàn)不可預(yù)料的錯(cuò)誤。在問(wèn)題出現(xiàn)的時(shí)候,有一個(gè)規(guī)劃好的降級(jí)程序?qū)?huì)極大的減少你的應(yīng)用停工期。期待你在下面發(fā)表評(píng)論和提問(wèn)。

英文原文:MySQL upgrade best practices

譯文出自:http://www.oschina.net/translate/mysql-upgrade-best-practices

責(zé)任編輯:林師授 來(lái)源: 開(kāi)源中國(guó)社區(qū) 編譯
相關(guān)推薦

2018-01-09 14:28:55

系統(tǒng)場(chǎng)景實(shí)踐

2021-10-12 10:43:38

區(qū)塊鏈技術(shù)智能

2016-11-09 21:09:54

mysqlmysql優(yōu)化

2017-12-14 15:01:20

智能分析實(shí)踐

2011-08-11 09:45:25

2012-01-09 11:35:01

WebApp最佳實(shí)踐策略

2024-08-29 09:32:36

2022-12-07 08:31:45

ClickHouse并行計(jì)算數(shù)據(jù)

2023-02-08 16:34:05

數(shù)據(jù)庫(kù)工具

2023-12-06 09:00:00

2023-09-13 08:00:00

JavaScript循環(huán)語(yǔ)句

2015-09-15 16:01:40

混合IT私有云IT架構(gòu)

2016-12-27 08:49:55

API設(shè)計(jì)策略

2023-07-21 01:12:30

Reactfalse?變量

2011-08-18 11:05:21

jQuery

2021-03-04 11:06:05

自助服務(wù)

2015-10-12 17:40:12

數(shù)據(jù)分析實(shí)踐

2011-07-26 09:31:39

Windows Ser

2023-08-21 08:19:22

ADB數(shù)據(jù)湖分析
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)