詳解在Linux中同時安裝配置並使用 MySQL5.7 和 MySQL8.0

来源:https://www.cnblogs.com/fx67ll/archive/2022/04/30/linux-install-mysql-with2version.html
-Advertisement-
Play Games

最近需要使用mysql8.0版本,但是原本的mysql5.7版本已經被多個服務依賴,於是想想能不能同一臺伺服器裝多個版本的mysql,一查確實可行,這裡做一個記錄方便自己後期回憶 閱讀本文前請註意!!! 本文是幫助您建立在mysql5.7版本已經安裝完成併在運行中,另外安裝配置mysql8.0版本 ...


最近需要使用mysql8.0版本,但是原本的mysql5.7版本已經被多個服務依賴,於是想想能不能同一臺伺服器裝多個版本的mysql,一查確實可行,這裡做一個記錄方便自己後期回憶

閱讀本文前請註意!!!

  1. 本文是幫助您建立在mysql5.7版本已經安裝完成併在運行中,另外安裝配置mysql8.0版本
  2. 如果需要同時安裝兩個版本,可以先查閱我之前所寫關於mysql5.7版本的安裝,完成後再按本文繼續操作即可

安裝環境

CentOS7 + MySQL8.0

下載安裝包

  1. 點擊進入MySQL Community Server 8.0.29 官網下載地址
  2. 點擊下拉選擇 Linux - Generic,找到名為 mysql-8.0.29-linux-glibc2.12-x86_64.tar.xz 點擊下載即可

簡化版命令步驟

給我自己的提醒:原來的mysql5.7配置基本沒有動,服務也沒有關,下麵的命令都是關於mysql8.0的,原mysql5.7的配置文件在/etc/my.cnf

  1. 解壓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/
  2. 賦予許可權 chown -R mysql.mysql /usr/soft/install/mysql-8.0.29-linux-glibc2.12-x86_64
  3. 修改配置文件 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
    
  4. 賦予配置文件許可權 chmod 755 /usr/soft/install/mysql-8.0.29-linux-glibc2.12-x86_64/my.cnf
  5. 修改連接服務文件 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
    
  6. 複製註冊連接服務文件 cp -i /usr/soft/install/mysql-8.0.29-linux-glibc2.12-x86_64/support-files/mysql.server /etc/init.d/mysql80
  7. 初始化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: 初始密碼
  8. 啟動mysql80服務 service mysql80 start,然後要記得開放防火牆的3307埠才能使用外部連接
  9. 登錄 /usr/soft/install/mysql-8.0.29-linux-glibc2.12-x86_64/bin/mysql --socket=/tmp/mysql80.sock -u root -p'初始密碼'
  10. 重置密碼,登錄後依次執行命令
    • 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;
  11. 查看占用埠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埠流程

  1. cd /etc/sysconfig進入該目錄,檢查是否存儲了iptables文件
  2. vim iptables使用vim編輯器修改iptables文件,按下i進入編輯模式
  3. 在初始埠那行下麵添加-A INPUT -p tcp -m state --state NEW -m tcp --dport 3307 -j ACCEPT,開放3307埠
  4. service iptables restart重啟防火牆即可

如何mysql80服務啟動失敗

可以參考一下步驟重新初始化資料庫,親測有效

  1. 刪除data文件夾 rm -rf /usr/soft/install/mysql-8.0.29-linux-glibc2.12-x86_64/data
  2. 新建data目錄 mkdir /usr/soft/install/mysql-8.0.29-linux-glibc2.12-x86_64/data
  3. 賦予許可權 chown -R mysql.mysql /usr/soft/install/mysql-8.0.29-linux-glibc2.12-x86_64
  4. 重新初始化 /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
  5. 測試啟動服務 service mysql80 start,成功即可

參考文檔

  1. linux 下同時安裝 mysql5.7 和 mysql8.0
  2. linux安裝兩個mysql(8.0和5.7),並同時使用
  3. tar.xz文件如何解壓
  4. linux mysql8 初始密碼修改
  5. linux下查看mysql埠號和修改埠號方法

我是 fx67ll.com,如果您發現本文有什麼錯誤,歡迎在評論區討論指正,感謝您的閱讀!
如果您喜歡這篇文章,歡迎訪問我的 本文github倉庫地址,為我點一顆Star,Thanks~

您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 有朋友好奇為什麼將 閉包 歸於語法糖,這裡簡單聲明下,C# 中的所有閉包最終都會歸結於 類 和 方法,為什麼這麼說,因為 C# 的基因就已經決定了,如果大家瞭解 CLR 的話應該知道, C#中的類最終都會用 MethodTable 來承載,方法都會用 MethodDesc 來承載, 所以不管你怎麼玩 ...
  • linux網路編程示例 簡單TCP、UDP編程示例。 TCP TCP客戶端與伺服器通信模型 伺服器代碼 #include <sys/socket.h> #include <netinet/in.h> #include <arpa/inet.h> #include <errno.h> #include ...
  • Linux下實現I/O復用的系統調用方式主要:select、poll、epoll。 ...
  • 從零部署.NetCore到Linux 購買Ubuntu伺服器 購買伺服器 創建root用戶,設置密碼 # 創建root用戶 sudo passwd root # 輸入兩次密碼 啟動ssh 系統預設是關閉的,需要打開下。 安裝Nginx 如何在 Ubuntu 20.04 上安裝 Nginx sudo命 ...
  • 前言 用騰訊雲伺服器Ubuntu搭建完SSH服務後,隔了一段時間重裝了伺服器系統,搭建的時候想著直接按照原先的博客梭哈就完事了Windows10公鑰遠程連接Linux伺服器結果就是各種失敗,耗費不少時間去解決,其中馬虎問題最嚴重。在此記錄分享,望能對大家有所幫助。Windows10公鑰遠程連接Lin ...
  • 鏡像下載、功能變數名稱解析、時間同步請點擊 阿裡雲開源鏡像站 一、在兩台機器上安裝docker // 1.安裝Docker源 yum install -y wget && wget https://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.rep ...
  • 前言 由於CentOS 8的支持已經到期了,.NET 6也不支持了,然後也無法升級,導致使用起來已經非常不便,無奈只有遷移伺服器這個選項了。 選擇發行版本一直是一個比較頭疼的問題,首先我不是專門運維的,最好使用的人比較多的版本,然後.NET要官方支持的版本才行,最好是具有中國區的鏡像服務。雖然Fed ...
  • ** linux 下需要知道你系統的Linux內核版本,然後選擇相應的版本下載,版本查詢命令:** uname -a 在高版本20.04和18.04等版本,不需要執行下麵這條命令來編譯makefile文件,因為系統自身存在串口驅動cp210x.o make 於是只需要在[/lib/modules/5 ...
一周排行
    -Advertisement-
    Play Games
  • Timer是什麼 Timer 是一種用於創建定期粒度行為的機制。 與標準的 .NET System.Threading.Timer 類相似,Orleans 的 Timer 允許在一段時間後執行特定的操作,或者在特定的時間間隔內重覆執行操作。 它在分散式系統中具有重要作用,特別是在處理需要周期性執行的 ...
  • 前言 相信很多做WPF開發的小伙伴都遇到過表格類的需求,雖然現有的Grid控制項也能實現,但是使用起來的體驗感並不好,比如要實現一個Excel中的表格效果,估計你能想到的第一個方法就是套Border控制項,用這種方法你需要控制每個Border的邊框,並且在一堆Bordr中找到Grid.Row,Grid. ...
  • .NET C#程式啟動閃退,目錄導致的問題 這是第2次踩這個坑了,很小的編程細節,容易忽略,所以寫個博客,分享給大家。 1.第一次坑:是windows 系統把程式運行成服務,找不到配置文件,原因是以服務運行它的工作目錄是在C:\Windows\System32 2.本次坑:WPF桌面程式通過註冊表設 ...
  • 在分散式系統中,數據的持久化是至關重要的一環。 Orleans 7 引入了強大的持久化功能,使得在分散式環境下管理數據變得更加輕鬆和可靠。 本文將介紹什麼是 Orleans 7 的持久化,如何設置它以及相應的代碼示例。 什麼是 Orleans 7 的持久化? Orleans 7 的持久化是指將 Or ...
  • 前言 .NET Feature Management 是一個用於管理應用程式功能的庫,它可以幫助開發人員在應用程式中輕鬆地添加、移除和管理功能。使用 Feature Management,開發人員可以根據不同用戶、環境或其他條件來動態地控制應用程式中的功能。這使得開發人員可以更靈活地管理應用程式的功 ...
  • 在 WPF 應用程式中,拖放操作是實現用戶交互的重要組成部分。通過拖放操作,用戶可以輕鬆地將數據從一個位置移動到另一個位置,或者將控制項從一個容器移動到另一個容器。然而,WPF 中預設的拖放操作可能並不是那麼好用。為瞭解決這個問題,我們可以自定義一個 Panel 來實現更簡單的拖拽操作。 自定義 Pa ...
  • 在實際使用中,由於涉及到不同編程語言之間互相調用,導致C++ 中的OpenCV與C#中的OpenCvSharp 圖像數據在不同編程語言之間難以有效傳遞。在本文中我們將結合OpenCvSharp源碼實現原理,探究兩種數據之間的通信方式。 ...
  • 一、前言 這是一篇搭建許可權管理系統的系列文章。 隨著網路的發展,信息安全對應任何企業來說都越發的重要,而本系列文章將和大家一起一步一步搭建一個全新的許可權管理系統。 說明:由於搭建一個全新的項目過於繁瑣,所有作者將挑選核心代碼和核心思路進行分享。 二、技術選擇 三、開始設計 1、自主搭建vue前端和. ...
  • Csharper中的表達式樹 這節課來瞭解一下表示式樹是什麼? 在C#中,表達式樹是一種數據結構,它可以表示一些代碼塊,如Lambda表達式或查詢表達式。表達式樹使你能夠查看和操作數據,就像你可以查看和操作代碼一樣。它們通常用於創建動態查詢和解析表達式。 一、認識表達式樹 為什麼要這樣說?它和委托有 ...
  • 在使用Django等框架來操作MySQL時,實際上底層還是通過Python來操作的,首先需要安裝一個驅動程式,在Python3中,驅動程式有多種選擇,比如有pymysql以及mysqlclient等。使用pip命令安裝mysqlclient失敗應如何解決? 安裝的python版本說明 機器同時安裝了 ...