最近需要使用mysql8.0版本,但是原本的mysql5.7版本已經被多個服務依賴,於是想想能不能同一臺伺服器裝多個版本的mysql,一查確實可行,這裡做一個記錄方便自己後期回憶 閱讀本文前請註意!!! 本文是幫助您建立在mysql5.7版本已經安裝完成併在運行中,另外安裝配置mysql8.0版本 ...
最近需要使用mysql8.0版本,但是原本的mysql5.7版本已經被多個服務依賴,於是想想能不能同一臺伺服器裝多個版本的mysql,一查確實可行,這裡做一個記錄方便自己後期回憶
閱讀本文前請註意!!!
- 本文是幫助您建立在
mysql5.7
版本已經安裝完成併在運行中,另外安裝配置mysql8.0
版本 - 如果需要同時安裝兩個版本,可以先查閱我之前所寫關於
mysql5.7
版本的安裝,完成後再按本文繼續操作即可
安裝環境
CentOS7 + MySQL8.0
下載安裝包
- 點擊進入MySQL Community Server 8.0.29 官網下載地址
- 點擊下拉選擇
Linux - Generic
,找到名為mysql-8.0.29-linux-glibc2.12-x86_64.tar.xz
點擊下載即可
簡化版命令步驟
給我自己的提醒:原來的mysql5.7
配置基本沒有動,服務也沒有關,下麵的命令都是關於mysql8.0
的,原mysql5.7
的配置文件在/etc/my.cnf
- 解壓xz文件為tar文件,註意命令無過程顯示需要等待視窗跳至下一行
xz -d /usr/soft/sort/mysql-8.0.29-linux-glibc2.12-x86_64.tar.xz -C /usr/soft/sort/
tar -xvf /usr/soft/sort/mysql-8.0.29-linux-glibc2.12-x86_64.tar -C /usr/soft/install/
- 賦予許可權
chown -R mysql.mysql /usr/soft/install/mysql-8.0.29-linux-glibc2.12-x86_64
- 修改配置文件
vi /usr/soft/install/mysql-8.0.29-linux-glibc2.12-x86_64/my.cnf
[client] port=3307 # mysql57 不要這個 mysqlx_port=33070 socket=/tmp/mysql80.sock # mysql57 不要這個 mysqlx_socket=/tmp/mysqlx80.sock [mysqld] # skip-grant-tables # mysql安裝目錄 basedir=/usr/soft/install/mysql-8.0.29-linux-glibc2.12-x86_64 # mysql資料庫目錄 datadir=/usr/soft/install/mysql-8.0.29-linux-glibc2.12-x86_64/data port=3307 innodb_file_per_table=1 character-set-server=utf8 # mysql57 不要這個 mysqlx_port=33070 socket = /tmp/mysql80.sock # mysql57 不要這個 mysqlx_socket=/tmp/mysqlx80.sock [mysqld_safe] # 錯誤日誌 log-error=/usr/soft/install/mysql-8.0.29-linux-glibc2.12-x86_64/data/error.log # pid文件 pid-file=/usr/soft/install/mysql-8.0.29-linux-glibc2.12-x86_64/data/mysqld.pid tmpdir=/tmp/mysql80
- 賦予配置文件許可權
chmod 755 /usr/soft/install/mysql-8.0.29-linux-glibc2.12-x86_64/my.cnf
- 修改連接服務文件
vi /usr/soft/install/mysql-8.0.29-linux-glibc2.12-x86_64/support-files/mysql.server
# 這兩項在開頭比較好找 basedir=/usr/soft/install/mysql-8.0.29-linux-glibc2.12-x86_64 datadir=/usr/soft/install/mysql-8.0.29-linux-glibc2.12-x86_64/data # 這項預設的不用找 lockdir='/var/lock/subsys' # 這項預設有但是需要在最後改個80 lock_file_path="$lockdir/mysql80" # 下麵兩個藏在下麵細心的找一下 mysqld_pid_file_path=/usr/soft/install/mysql-8.0.29-linux-glibc2.12-x86_64/data/mysqld.pid conf=/usr/soft/install/mysql-8.0.29-linux-glibc2.12-x86_64/my.cnf
- 複製註冊連接服務文件
cp -i /usr/soft/install/mysql-8.0.29-linux-glibc2.12-x86_64/support-files/mysql.server /etc/init.d/mysql80
- 初始化mysql80
/usr/soft/install/mysql-8.0.29-linux-glibc2.12-x86_64/bin/mysqld --defaults-file=/usr/soft/install/mysql-8.0.29-linux-glibc2.12-x86_64/my.cnf --user=mysql --initialize
- root@localhost: 初始密碼
- 啟動mysql80服務
service mysql80 start
,然後要記得開放防火牆的3307埠才能使用外部連接 - 登錄
/usr/soft/install/mysql-8.0.29-linux-glibc2.12-x86_64/bin/mysql --socket=/tmp/mysql80.sock -u root -p'初始密碼'
- 重置密碼,登錄後依次執行命令
flush privileges;
- 註意:新版本mysql8後,不再支持
password()
方法,只能通過alter
語句進行修改 ALTER USER 'root'@'localhost' IDENTIFIED BY '你的密碼';
- 如果不行可以試試
ALTER USER 'root'@'%' IDENTIFIED BY '你的密碼';
use mysql;
update user set host='%' where user='root' and host='localhost';
flush privileges;
- 查看占用埠
show global variables like 'port';
,如果發現為0,需要執行以下步驟修改- 停止服務:
service mysql80 stop
- 修改配置文件:
vi /usr/soft/install/mysql-8.0.29-linux-glibc2.12-x86_64/my.cnf
,將 [mysqld] 下的 skip-grant-tables 註釋 - 重新啟動服務:
service mysql80 start
- 停止服務:
開啟3307埠流程
cd /etc/sysconfig
進入該目錄,檢查是否存儲了iptables
文件vim iptables
使用vim編輯器
修改iptables
文件,按下i
進入編輯模式- 在初始埠那行下麵添加
-A INPUT -p tcp -m state --state NEW -m tcp --dport 3307 -j ACCEPT
,開放3307埠 service iptables restart
重啟防火牆即可
如何mysql80服務啟動失敗
可以參考一下步驟重新初始化資料庫,親測有效
- 刪除data文件夾
rm -rf /usr/soft/install/mysql-8.0.29-linux-glibc2.12-x86_64/data
- 新建data目錄
mkdir /usr/soft/install/mysql-8.0.29-linux-glibc2.12-x86_64/data
- 賦予許可權
chown -R mysql.mysql /usr/soft/install/mysql-8.0.29-linux-glibc2.12-x86_64
- 重新初始化
/usr/soft/install/mysql-8.0.29-linux-glibc2.12-x86_64/bin/mysqld --defaults-file=/usr/soft/install/mysql-8.0.29-linux-glibc2.12-x86_64/my.cnf --user=mysql --initialize
- 測試啟動服務
service mysql80 start
,成功即可
參考文檔
- linux 下同時安裝 mysql5.7 和 mysql8.0
- linux安裝兩個mysql(8.0和5.7),並同時使用
- tar.xz文件如何解壓
- linux mysql8 初始密碼修改
- linux下查看mysql埠號和修改埠號方法
我是 fx67ll.com,如果您發現本文有什麼錯誤,歡迎在評論區討論指正,感謝您的閱讀!
如果您喜歡這篇文章,歡迎訪問我的 本文github倉庫地址,為我點一顆Star,Thanks~