目錄
- linux mysql5.5升級至mysql5.7
- 1.下載mysql5.7.32
- 2. 進入舊的mysql的bin目錄下導(dǎo)出mysql的數(shù)據(jù)
- 3. 進入新的mysql根目錄下創(chuàng)建存放數(shù)據(jù)的data目錄
- 4. 對于剛解壓的新數(shù)據(jù)庫,首先執(zhí)行初始化命令
- 5. 設(shè)置跳過密碼登錄
- 6. 啟動服務(wù)
- 7. 設(shè)置密碼
- 8. 停止服務(wù)
- 9. 啟動服務(wù)
- 10. 新命令行登錄
- 11. 設(shè)置其他ip可以連接mysql
- 12. 導(dǎo)入歷史數(shù)據(jù)
- 13. 執(zhí)行更新
- MySQL從5.5升級到5.7
- 1.升級方式
- 2.環(huán)境介紹
- 3.升級思路
- 4.實在演練
- 4.1.登陸到mysql-proxy中將其中一臺從庫從集群中踢出
- 4.2.替換mysql的安裝目錄
- 4.3.啟動mysql服務(wù)
- 4.4.升級系統(tǒng)表數(shù)據(jù)字典信息,命令如下:
- 4.5.升級完以后重啟一下mysql
- 4.6.重新做一下主從配置
- 4.7加入到讀寫分離的集群中
- Mysql5.5升級到5.7的過程已經(jīng)踩到的坑
- 1、卸載數(shù)據(jù)庫
- 2、安裝新數(shù)據(jù)庫
- 3、配置
linux mysql5.5升級至mysql5.7
下面先分享一個簡單的升級mysql的步驟,后面腳本之家小編為大家整理了多個補充,大家可以參考一下。
1.下載mysql5.7.32
官方下載地址 https://dev.mysql.com/downloads/mysql/
解壓
tar xvf mysql.tar.gz mysql/
2. 進入舊的mysql的bin目錄下導(dǎo)出mysql的數(shù)據(jù)
./mysql -uroot -pxxxx -h127.0.0.1 -P3306 /home/mysql5.5/bin/all.sql
3. 進入新的mysql根目錄下創(chuàng)建存放數(shù)據(jù)的data目錄
mkdir data
4. 對于剛解壓的新數(shù)據(jù)庫,首先執(zhí)行初始化命令
cd bin
./mysql_install_db --basedir=../ --datadir=../data
PS: 以上升級是在Cent OS上的,但是在中標麒麟我升級的時候,發(fā)現(xiàn)不認識上面的語句,需要替換成下面這個初始化語句
./mysqld --defaults-file=../my.cnf --basedir=../ --datadir=../data --user=root --initialize
5. 設(shè)置跳過密碼登錄
在my.cnf 中的[mysqld]中添加skip-grant-tables
my.cnf 為數(shù)據(jù)庫的配置文件
6. 啟動服務(wù)
./mysqld --defaults-file=../my.cnf --basedir=../ --datadir=../data --user=root
7. 設(shè)置密碼
在新的命令行窗口登錄mysql
./mysql -uroot
use mysql;
update mysql.user set authentication_string=password('xxxx') where user='root';
8. 停止服務(wù)
注釋掉配置文件中的skip-grant-tables
9. 啟動服務(wù)
./mysqld --defaults-file=../my.cnf --basedir=../ --datadir=../data --user=root
10. 新命令行登錄
./mysql -uroot -pxxxx
use mysql;
這個時候:不管運行任何命令,總是提示這個 You must reset your password using ALTER USER statement before executing this statement.
這時執(zhí)行下面的語句
SET PASSWORD = PASSWORD('xxxx');
11. 設(shè)置其他ip可以連接mysql
use mysql;
grant all privileges on *.* to "root"@"%" identified by "xxxx";
12. 導(dǎo)入歷史數(shù)據(jù)
cd bin
./mysql -uroot -pxxxx -h127.0.0.1 -P3306 /home/mysql5.5/bin/all.sql
13. 執(zhí)行更新
cd bin
./mysql_upgrade
14. 升級后可能出現(xiàn)查詢語句出現(xiàn)報錯的情況,可執(zhí)行下面的語句
set @@sql_mode ='STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION';
set sql_mode ='STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION';
下面是其他網(wǎng)友的補充
MySQL從5.5升級到5.7
最近有個任務(wù)將MySQL從5.5版本升級到5.7,沒升級過數(shù)據(jù)庫,只能摸索的前進。上網(wǎng)找了一堆資料。目測看只有兩種升級方式
1.升級方式
1.Logical Upgrade(邏輯升級):利用mysqldump來直接導(dǎo)出SQL文件,然后起一個新的MySQL5.7庫,將導(dǎo)出的SQL文件導(dǎo)入到新庫中,當然如果采用這種方式的話建議不要用mysqldump而使用mydumper.因為我們公司的數(shù)據(jù)量很大所以沒有采用這個方法來處理。
2.In-Place Upgrade:這個升級方法簡單快速,就是直接替換原來的MySQL的安裝目錄和/etc/my.cnf配置文件,利用mysql_upgrade腳本來完成系統(tǒng)表的升級。
2.環(huán)境介紹
我們的mysql集群采用的是Atlas讀寫分離,mysql-proxy下有4臺數(shù)據(jù)庫服務(wù)器:
master: 172.16.100.1
slave1:172.16.100.2
slave2:172.16.100.3
slave3:172.16.100.4
當前數(shù)據(jù)庫版本:”5.5.21
配置文件:/etc/my.cnf
數(shù)據(jù)目錄:/data/mysql
操作系統(tǒng)版本:CentOS6.9
3.升級思路
因為是線上業(yè)務(wù)不能中斷,所以決定先將其中一臺slave踢出集群,并升級到mysql5.7,然后再講mysql5.7這臺設(shè)備加入到集群當中,等數(shù)據(jù)同步完了再做主備切換,再升級其他的slave節(jié)點。
4.實在演練
4.1.登陸到mysql-proxy中將其中一臺從庫從集群中踢出
mysql -uuser -ppwd -h127.0.0.1 -P234
查看后端代理庫
mysql> SELECT * FROM backends;
+-------------+-------------------+-------+------+
| backend_ndx | address | state | type |
+-------------+-------------------+-------+------+
| 1 | 172.16.100.1:3306 | up | rw |
| 2 | 172.16.100.2:3306 | up | ro |
| 3 | 172.16.100.3:3306 | up | ro |
| 4 | 172.16.100.4:3306 | up | ro |
+-------------+-------------------+-------+------+
5 rows in set (0.00 sec)
將服務(wù)172.16.100.4從集群中踢出
mysql> remove backend 4
4.2.替換mysql的安裝目錄
到mysql的官網(wǎng)下載mysql5.7版本mysql-5.7.23-linux-glibc2.12-x86_64.tar.gz
解壓mysql5.7
tar -zxf mysql-5.7.23-linux-glibc2.12-x86_64.tar.gz -C /usr/local/
如果你之前的mysql目錄是鏈接的方式創(chuàng)建的話,那么只需要取消鏈接,從新做一下鏈接就可以了
cd /usr/local/
unlink mysql
ln -s mysql-5.7.23-linux-glibc2.12-x86_64 mysql
如果你之前的mysql目錄不是鏈接的方式,那么重新命名一下,再鏈接一個mysql目錄就可以了
cd /usr/local/
mv mysql mysql5.5
ln -s mysql-5.7.23-linux-glibc2.12-x86_64 mysql(建議盡可能的使用這種方式,比較方便升級)
4.3.啟動mysql服務(wù)
mysql5.7以后是不需要進行數(shù)據(jù)庫初始化的,也就是不用去執(zhí)行mysql_install_db這個命令
/usr/local/mysql/bin/mysqld_safe --datadir=/data/mysql --basedir=/usr/local/mysql --user=mysql --skip-grant-tables --skip-networking
ps -ef |grep mysql
如果有出息錯誤的話查看日志信息
4.4.升級系統(tǒng)表數(shù)據(jù)字典信息,命令如下:
/usr/loca/mysql/bin/mysql_upgrade
輸出的結(jié)果:
可能會有一些error提示"ALTER TABLE ** FROCE",這些錯誤不用擔心mysql在后面會自動修復(fù)repair的時間可能會有點長,要看你的數(shù)據(jù)庫情況,我這次升級花了兩個多小時
最后如果輸出Upgrade process completed successfully那么就表示升級成功了。
4.5.升級完以后重啟一下mysql
/usr/local/mysql/bin/mysqld_safe --datadir=/data/mysql --basedir=/usr/local/mysql --user=mysql
查看一下是否升級完了,如果升級成功的話輸出如下
This installation of MySQL is already upgraded to 5.7.23, use --force if you still need to run mysql_upgrade
4.6.重新做一下主從配置
重做一下主從配置
mysql> change master to master master_host="172.16.100.1",master_user="***",master_passowrd="***",master_log_file=" mysql-bin.000004", master_log_pos=1083;
mysql> start slave;
mysql> show slave status\G;
如果兩個yes就說明正常了
4.7加入到讀寫分離的集群中
到mysql-proxy設(shè)備上面
mysql -uuser -ppwd -h127.0.0.1 -P234
mysql> ADD SLAVE 172.16.100.4
mysql> select * from backends;
如果state的狀態(tài)是up的就說明加入集群成功了。
后記:
我第一次升級數(shù)據(jù)庫,不知道整體思路對不對,先在測試環(huán)境上面做的測試,然后又測了幾天沒有問題了才在線上做的升級。僅供參考。
Mysql5.5升級到5.7的過程已經(jīng)踩到的坑
故事是這樣子的,我們公司有幾臺老的mysql版本是5.5的,最近項目做了一些升級增加了幾個字段,用spring-data-jpa自動刷新表結(jié)構(gòu)的時候報錯了,原因是mysql5.5的版本不支持一張表里面有兩個以上的 current_timestamp 作為default value。所以就要考慮升級下數(shù)據(jù)庫
先到服務(wù)器上面看了下版本
再看了下源
哦,順帶提一句,我們公司在用的aws 的 ec2 ,所以都是amz的源
試了下 yum update mysql-server 然后并沒什么卵用,所以繼續(xù)往下搞。
網(wǎng)上看了好多都說是先把舊版本的數(shù)據(jù)庫卸載了再用裝新版本的數(shù)據(jù)庫,那我的里面的數(shù)據(jù)咋辦,為了保險起見,我先辦數(shù)據(jù)庫做了個備份,一個庫一個庫的備份,我看mysql庫里面也配了好多用戶和權(quán)限,就順便也把mysql備份了,然后開搞。
1、卸載數(shù)據(jù)庫
yum remove mysql-server
但是我們這邊裝的好像不太一樣,我就把剛才yum查到的幾個都卸載了。
卸載前記得把mysql服務(wù)關(guān)掉,要不然裝新版本之后用mysql --version 查看是5.7 mysql 登錄進去還是5.5然后重啟服務(wù)就各種問題。因為有些文件沒被刪掉,導(dǎo)致新裝的數(shù)據(jù)庫好奇怪的樣子。。。
2、安裝新數(shù)據(jù)庫
yum search mysql57
先看看有什么版本可以選,這個沒啥說的直接
yum install msyql57-server.x86_64
安裝下來就ok,來看看都裝了些啥東西
很奇怪一點就是mysql-config依賴竟然還是5.5的,不過用起來沒發(fā)現(xiàn)啥問題
3、配置
安裝好了之后修改以下my.cnf
我的服務(wù)器上面是在/etc/my.cnf 不知道其它的鏡像有沒有變化
在配置的時候我突然想到數(shù)據(jù)存儲的空間是還在的啊,配過去看看能用不
于是就在my.cnf配了這一行(5.5的好多配置都棄用了,之前的my.cnf里面的都要刪一刪要不然啟動時會報錯)
配置之后果斷啟動服務(wù)
service mysqld start
果然報錯了
看了下啟動日志
[ERROR] Fatal error: mysql.user table is damaged. Please run mysql_upgrade.
ERROR: Zend_Db_Adapter_Exception: SQLSTATE[HY000] [2002] No such file or directoryAdditionally, an exception has occurred while trying to report this error: Zend_ExceptionNo entry is registered for key 'translate' (Abstract.php:144)
臥槽,這咋辦google一波 搜到了這篇文章https://support.plesk.com/hc/en-us/articles/115001659169-MySQL-fails-to-start-mysql-user-table-is-damaged
具體解決方法如下
a. 登錄到那臺服務(wù)器主機上面
b. Add skip-grant-tables in /etc/my.cnf
file under [mysqld]
section 意思就是開啟安全模式(不驗證密碼什么的)
c. service mysqld start
d. mysql_upgrade
e. service mysqld restart
我執(zhí)行了一下mysql_upgrade
查了查官方文檔,大體意思就是升級之后好多東西不怎么兼容,官方提供這個腳本來修復(fù)之前的工作空間
果然是無縫升級mysql數(shù)據(jù)庫中的用戶都還在之前的數(shù)據(jù)庫也沒有受到影響
至此升級完成
到此這篇關(guān)于linux mysql5.5升級至mysql5.7的詳細步驟的文章就介紹到這了,更多相關(guān)mysql5.5升級至5.7內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
您可能感興趣的文章:- Linux下MySQL多實例部署及安裝指南
- Linux下mysql 8.0.25 安裝配置方法圖文教程
- 一臺linux主機啟動多個MySQL數(shù)據(jù)庫的方法
- 解決Linux安裝mysql 在/etc下沒有my.cnf的問題
- linux下利用Docker安裝mysql的步驟
- Linux手動部署遠程的mysql數(shù)據(jù)庫的方法詳解
- linux使用mysqldump+expect+crontab實現(xiàn)mysql周期冷備份思路詳解
- Aliyun Linux 編譯安裝 php7.3 tengine2.3.2 mysql8.0 redis5的過程詳解
- Mysql如何在linux中實現(xiàn)定時備份
- Linux mysql-5.6如何實現(xiàn)重置root密碼
- 在Ubuntu/Linux環(huán)境下使用MySQL開放/修改3306端口和開放訪問權(quán)限
- MySQL定時備份方案(利用Linux crontab)
- linux環(huán)境下安裝mysql數(shù)據(jù)庫的詳細教程
- Linux下mysql異地自動備份的方法
- Linux MySQL忘記root密碼解決方案
- Linux下安裝mysql-8.0.20的教程詳解
- Linux如何使用 MyCat 實現(xiàn) MySQL 主從讀寫分離