1、概述通常,從一個(gè)發(fā)布版本升級到另一個(gè)版本時(shí),我們建議按照順序來升級版本。例如,想要升級 MySQL 3.23 時(shí),先升級到 MySQL 4.0,而不是直接升級到 MySQL 4.1 或 MySQL 5.0。 以下是在升級 MySQL 時(shí)需要注意的事項(xiàng): 仔細(xì)閱讀一下升級的目標(biāo)版本的新特性和改變的特性,以及2個(gè)版本之間的不同特性 升級前一定要備份所有的數(shù)據(jù) 如果是在Windows平臺上升級MySQL,請閱讀附錄 "在Windows平臺上升級MySQL" 有些不同版本間的升級可能會(huì)涉及對授權(quán)表的修改,請尤其注意這個(gè)問題,詳情請閱讀附錄 "升級授權(quán)表" ◆如果正在運(yùn)行著同步,請閱讀附錄 "升級同步" ◆如果之前運(yùn)行著MySQL-Max發(fā)布版本,想要升級到非MySQL-Max發(fā)布版本時(shí),就需要從 mysqld_safe 去掉啟動(dòng) mysqld-max 服務(wù)器的參數(shù) 在同一個(gè)發(fā)布系列版本的MySQL間,可以隨意拷貝格式文件和數(shù)據(jù)文件。如果在MySQL運(yùn)行過程中改變了字符集,就需要對每個(gè)MyISAM表執(zhí)行 "myisamchk -r -q --set-character-set=charset" 命令修復(fù)一下。否則的話,索引的排序可能不正確,因?yàn)樾薷牧俗址涂赡軙?huì)改變索引的順序。 通常情況下,升級到新版本不需要修改任何數(shù)據(jù)表。請檢查MySQL發(fā)布事項(xiàng)中提到的升級需要注意的地方,如果發(fā)現(xiàn)不能直接升級的話,就先用 mysqldump 將數(shù)據(jù)導(dǎo)出來,然后再導(dǎo)回去。 如果擔(dān)心升級失敗,就先把舊版本的MySQL改個(gè)名字備份起來,以備所需。 同時(shí),升級完之后可能還需要重新編譯跟MySQL相關(guān)的程序,因?yàn)樾掳姹镜念^文件和庫文件可能有改變了。 如果升級后發(fā)生問題了,請先檢查是否使用了舊的my.cnf配置文件,可以通過執(zhí)行命令 "mysqld --print-defaults" 來打印出各種配置信息來確認(rèn)。 升級的時(shí)候最好也升級類似Perl的 DBD::mysql 模塊,同樣,對PHP和Python而言也是一樣。 2、從 MySQL 5.0 升級到 MySQL 5.1 從 5.0 升級到 5.1 的時(shí)候,必須要升級授權(quán)表。否則,可能某些存儲(chǔ)過程無法運(yùn)行。詳情請看附錄 "mysql_update MySQL升級時(shí)檢查數(shù)據(jù)表"。 以下是從 5.0 升級到 5.1 需要注意的事項(xiàng): 檢查所有的變化,尤其注意那些標(biāo)志為 "不兼容的變化" 的部分。詳情請看附錄 "mysql_update MySQL升級時(shí)檢查數(shù)據(jù)表" ◆可能某些發(fā)布版本會(huì)改變授權(quán)表的機(jī)制
創(chuàng)新互聯(lián)堅(jiān)持“要么做到,要么別承諾”的工作理念,服務(wù)領(lǐng)域包括:成都網(wǎng)站建設(shè)、網(wǎng)站建設(shè)、企業(yè)官網(wǎng)、英文網(wǎng)站、手機(jī)端網(wǎng)站、網(wǎng)站推廣等服務(wù),滿足客戶于互聯(lián)網(wǎng)時(shí)代的平樂網(wǎng)站設(shè)計(jì)、移動(dòng)媒體設(shè)計(jì)的需求,幫助企業(yè)找到有效的互聯(lián)網(wǎng)解決方案。努力成為您成熟可靠的網(wǎng)絡(luò)建設(shè)合作伙伴!
/etc/yum.repos.d/MariaDB.repo
1 升級必須是逐步遞增升級, 不能跨版本升級
2 升級后必須使用升級命令 mysql_upgrade
3 升級重啟后查看日志文件, 是否有錯(cuò)誤提示, 必須修復(fù)后才可進(jìn)行下一步升級
前天我剛回答了相似的問題你參考一下
1.導(dǎo)出4.0.23當(dāng)前數(shù)據(jù)庫數(shù)據(jù),進(jìn)行備份。
2.安裝4.1或5.1進(jìn)行備份數(shù)據(jù)導(dǎo)入。
3.具體操作
linux中升級MySQL應(yīng)采取的步驟:
1. 進(jìn)行升級前你應(yīng)先備份當(dāng)前的MySQL安裝。
2. 下載最新linux版MySQL。
3. 升級MySQL前,必須停止服務(wù)器。
如果服務(wù)器安裝為服務(wù),必須在命令提示符下在命令行中用命令停止服務(wù):
4.當(dāng)從以前至的4.0.23版本升級到4.1或5.1時(shí),或從Zip文件安裝的MySQL升級到MySQL Installation Wizard(安裝幫助)安裝的MySQL時(shí),你必須手動(dòng)卸載前面安裝的MySQL服務(wù)。
如果你不想卸載已有的服務(wù),MySQL Installation Wizard(安裝幫助)則不會(huì)正確安裝新的MySQL服務(wù)。
5. 如果你使用MySQL Installation Wizard(安裝幫助),請參考“使用MySQL安裝向?qū)А钡拿枋鰜韱?dòng)幫助。
6. 如果用Zip文件安裝MySQL,應(yīng)提取文件。你可以覆蓋已有的MySQL安裝,建議覆蓋原有的安裝。
7. 重新啟動(dòng)服務(wù)器。
1.先用SQLyog之類的圖形化數(shù)據(jù)庫管理工具把數(shù)據(jù)庫內(nèi)的所有東西備份出來。backup database as sql dump。注意要選structure and data (結(jié)構(gòu)和數(shù)據(jù))。導(dǎo)出sql文件后,確認(rèn)一下sql文件無誤。
2.系統(tǒng)中可能存在自帶的MySQL,采用命令進(jìn)行強(qiáng)制刪除
rpm –qa|grep mysql
rpm -e mysql-5.1.61 --nodeps 強(qiáng)制刪除mysql 不考慮依賴關(guān)系 (此處根據(jù)上一步查詢到的結(jié)果)
3.安裝mysql
rpm -ivh MySQL-server-community-5.1.61-0.rhel5.x86_64.rpm (包名根據(jù)實(shí)際情況)
4.在MySQL配置文件/etc/my.cnf中根據(jù)實(shí)際需要添加
lower_case_table_names=1
skip-name-resolve
event_scheduler=1
default-character-set=utf8
wait_timeout=31536000
interactive_timeout=31536000
5.啟動(dòng)服務(wù)
cd /etc/init.d
./mysql restart
或者service mysqld restart
6.登陸MySQL
/usr/local/mysql/bin/mysql -u root –p
7.新增用戶,根據(jù)允許訪問的地址和用戶,可能需要多次執(zhí)行。
GRANT ALL PRIVILEGES ON *.* TO 'user'@'192.168.1.1(你的ip)' IDENTIFIED BY 'password' WITH GRANT OPTION;
flush privileges;
8.
用SQLyog之類的圖形化數(shù)據(jù)庫管理工具把數(shù)據(jù)庫備份出來的sql語句執(zhí)行一遍
9.完成
1. 下載 5.7.30 的 zip 包并解壓到新的目錄。
2. 安裝 Visual C++ 2012/2013(或更多版本)。
3. 停應(yīng)用,停止 5.6 實(shí)例(可以通過停服務(wù)來操作,停止服務(wù)前建議記錄一下 GTID 或 binlog file 和 position 位置),刪除服務(wù)。
4. 備份一份 5.6 實(shí)例的 datadir,包括 binlog(整個(gè)目錄 copy 到別的目錄存放)。
5. 拷貝 5.6 實(shí)例的 datadir 和 my.ini 到 5.7 實(shí)例 basedir 目錄,調(diào)整并優(yōu)化參數(shù)值(注意要確保路徑一致,確認(rèn)已開啟 5.7 新特性相關(guān)參數(shù),如增強(qiáng)半同步、MTS 等)。
6. 修改系統(tǒng)環(huán)境變量,把可執(zhí)行路徑指向 5.7 實(shí)例的 basedir/bin。
7. 啟動(dòng) 5.7 實(shí)例,創(chuàng)建服務(wù)并啟動(dòng)。
8. 驗(yàn)證服務(wù)端、客戶端版本是否正確。
9. 確認(rèn)無誤后,執(zhí)行 mysql_upgrade 升級數(shù)據(jù)字典(會(huì)升級系統(tǒng)庫:mysql,ps,sys,沒有會(huì)重建)。
10. 重啟實(shí)例。
11. 再次校驗(yàn) 5.7 的參數(shù),盡量保持與 5.6 的兼容,尤其要注意 sql_mode 的默認(rèn)值對業(yè)務(wù)的影響。
12. 清理 5.6 實(shí)例的 basedir 和 datadir 目錄(可選)。
13. 如果是主從環(huán)境,還要考慮 slave_net_timeout 參數(shù)默認(rèn)值改變帶來的影響(主庫 error 日志中出現(xiàn) “ER_RPL_ZOMBIE_ENCOUNTERED” 的報(bào)錯(cuò))。
在 5.7.7 以前,該參數(shù)默認(rèn)是 3600s,之后改為了 60s,需要重新執(zhí)行 change master to 語句,并且顯式指定 master_heartbeat_period=xx,因?yàn)閺?5.7.4 開始,只有執(zhí)行 reset slave 才能將其重置為默認(rèn)值(slave_net_timeout 值的一半)。另外提一句,也是從 5.7.4 開始,執(zhí)行 change master to 語句時(shí),可以不用先停止復(fù)制線程了。