Linux:CentOS7安裝MySQL8(詳)


基於 Linux 的 CentOS 7 安裝 MySQL 8,包含以下步驟

  1. 安裝工作:卸載 MariaDB,下載資源包,檢查舊版本 MySQL,解壓安裝。
  2. 配置工作:基本設置,創建用戶組和用戶,數據目錄。
  3. 初始化 MySQL:配置文件,初始化。
  4. 啟動 MySQL:啟動服務,登錄,修改密碼,創建遠程連接用戶,退出和關閉。

1、安裝工作

1.1、卸載 MariaDB(❗)

1.1.1、MariaDB

MySQL 的一個分支,主要由開源社區維護。

  1. CentOS 7+ 不再默認使用 MySQL 數據庫,而是 MariaDB 數據庫。
  2. 直接安裝 MySQL 會與 MariaDB 的文件沖突。

👉 安裝 MySQL 之前,先卸載自帶的 MariaDB

1.1.2、卸載

步驟

  1. 查看版本:有則需要卸載。

    rpm -qa|grep mariadb
    
  2. 卸載:復制文件名,執行以下指令。

    rpm -e --nodeps 文件名
    
  3. 確認卸載

    rpm -qa|grep mariadb
    

圖示

image-20211124173745968

1.2、下載資源包

Hint將 MySQL 資源包放在 /usr/local/

2 種下載方式

1.2.1、官網下載

  1. 官網下載Linux - Generic (glibc 2.12) (x86, 64-bit)

  2. 上傳到服務器/usr/local/ 目錄下。

    image-20211125000605202

1.2.2、wget 下載

  1. wget 指令:在 /usr/local/ 下執行,下載資源包。

    # 格式:wget 資源地址
    wget https://dev.mysql.com/get/Downloads/MySQL-8.0/mysql-8.0.20-linux-glibc2.12-x86_64.tar.xz
    
  2. image-20211125002148348

1.3、檢查舊版本 MySQL

指令

rpm -qa|grep mysql
  • 沒有輸出:說明當前系統沒有安裝 MySQL,開始安裝。

  • 有輸出:顯示的 MySQL 不是想要的版本,則卸載。

    # 停止服務
    systemctl stop mysqld
    
    # 卸載
    rpm -e --nodeps mysql文件名
    

1.4、解壓安裝

解壓安裝

  1. 解壓:tar 指令。

    # .tar.gz 后綴
    tar -zxvf 文件名
    
    # .tar.xz 后綴
    tar -Jxvf 文件名
    
  2. 解壓完成/usr/local/ 下會生成 MySQL 文件夾

    image-20220510102743817

Hint將 MySQL 安裝在 /usr/local/

若沒有安裝在該目錄下,通過 mv 指令移動到該目錄。

2、配置工作(❗)

2.1、基本設置

安裝完成后的基本設置。

2.1.1、文件夾重命名

  • 重命名 MySQL 文件夾(或創建軟鏈接 👉文件管理 2.5

  • 通常命名為 mysql版本號

    # 重命名(也可通過Xftp修改)
    mv 原文件夾名 mysql8
    
    # 軟鏈接
    ln -s 文件夾名 mysql8
    

2.1.2、PATH 變量(❗)

添加 PATH 變量后,可在全局使用 MySQL

添加方式

  1. 臨時生效:export 命令(連接會話關閉后失效,通常用於測試環境)

    export PATH=$PATH:/usr/local/mysql8/bin
    
  2. 永久生效:修改配置文件。

2.1.3、確認安裝

  1. 查看版本

    • mysql --version
      
    • image-20211124211338766

  2. 確定 MySQL 安裝成功后,可刪除壓縮包。

    rm -rf 壓縮包名
    

2.2、創建用戶組、用戶(❗)

注:需要進入 /usr/local

  1. 創建用戶組groupadd

  2. 創建用戶useradd-r 創建系統用戶,-g 指定用戶組)

    groupadd mysql
    useradd -r -g mysql mysql
    

2.3、數據目錄(❗)

  1. 創建目錄

    mkdir -p /data/mysql8_data
    
  2. 賦予權限

    # 更改屬主和數組
    chown -R mysql:mysql /data/mysql8_data
    
    # 更改模式
    chmod -R 750 /data/mysql8_data
    

3、初始化 & 啟動(❗)

3.1、配置文件

/usr/local/etc/ 下創建 my.cnf 配置文件

用於初始化 MySQL 數據庫

3.1.1、配置方式

注:部分配置涉及 MySQL 文件夾名稱,若文件夾名不是 mysql8 則需修改。

  1. 在本地創建后,通過 Xftp 上傳

  2. 使用 Vim 編輯器 進行編輯

    • 進入 Vim 編輯器

      vim /usr/local/etc/my.cnf
      
    • i 進入輸入模式,粘貼以下配置

    • ESC 退出編輯模式,按 :wq 保存並退出

3.1.2、配置內容(❗)

[mysql]
# 默認字符集
default-character-set=utf8mb4
[client]
port       = 3306
socket     = /tmp/mysql.sock
[mysqld]
port       = 3306
server-id  = 3306
user       = mysql
socket     = /tmp/mysql.sock
# 安裝目錄
basedir    = /usr/local/mysql8
# 數據存放目錄
datadir    = /data/mysql8_data/mysql
log-bin    = /data/mysql8_data/mysql/mysql-bin
innodb_data_home_dir      =/data/mysql8_data/mysql
innodb_log_group_home_dir =/data/mysql8_data/mysql
# 日志及進程數據的存放目錄
log-error =/data/mysql8_data/mysql/mysql.log
pid-file  =/data/mysql8_data/mysql/mysql.pid
# 服務端字符集
character-set-server=utf8mb4
lower_case_table_names=1
autocommit =1
##### 以上涉及文件夾明,注意修改
skip-external-locking
key_buffer_size = 256M
max_allowed_packet = 1M
table_open_cache = 1024
sort_buffer_size = 4M
net_buffer_length = 8K
read_buffer_size = 4M
read_rnd_buffer_size = 512K
myisam_sort_buffer_size = 64M
thread_cache_size = 128
#query_cache_size = 128M
tmp_table_size = 128M
explicit_defaults_for_timestamp = true
max_connections = 500
max_connect_errors = 100
open_files_limit = 65535
binlog_format=mixed
binlog_expire_logs_seconds =864000
# 創建表時使用的默認存儲引擎
default_storage_engine = InnoDB
innodb_data_file_path = ibdata1:10M:autoextend
innodb_buffer_pool_size = 1024M
innodb_log_file_size = 256M
innodb_log_buffer_size = 8M
innodb_flush_log_at_trx_commit = 1
innodb_lock_wait_timeout = 50
transaction-isolation=READ-COMMITTED
[mysqldump]
quick
max_allowed_packet = 16M
[myisamchk]
key_buffer_size = 256M
sort_buffer_size = 4M
read_buffer = 2M
write_buffer = 2M
[mysqlhotcopy]
interactive-timeout

3.2、初始化(❗)

Hint:需要進入 /usr/local/mysql/bin,若添加了 PATH 變量可忽略。

初始化命令:注意文件夾名稱。

  • --defaults-file:指定配置文件(要放在--initialize 前面)

  • --user: 指定用戶

  • --basedir:指定安裝目錄

  • --datadir:指定初始化數據目錄

  • --intialize-insecure:初始化無密碼(否則生成隨機密碼)

    mysqld --defaults-file=/usr/local/etc/my.cnf --basedir=/usr/local/mysql8 --datadir=/data/mysql8_data/mysql --user=mysql --initialize-insecure
    

3.3、啟動 MySQL

查看 MySQL 的 /bin 下是否包含 mysqld_safe

用於后台安全啟動 MySQL

image-20211125013704323

3.3.1、啟動服務

  1. 安全后台啟動 MySQL

    • # 完整命令
      /usr/local/mysql8/bin/mysqld_safe --defaults-file=/usr/local/etc/my.cnf &
      # 若添加了PATH變量,可省略如下
      mysqld_safe --defaults-file=/usr/local/etc/my.cnf &
      
    • image-20211125014023161

  2. 確認啟動:第二條即 MySQL 服務。

    • ps -ef|grep mysql
      
    • image-20211125014115675

3.3.2、登錄

  • 無密碼:若以 --initialize-insecure 初始化,首次登錄時跳過密碼。

    mysql -u root --skip-password
    
  • 有密碼:若初始化時設置了隨機密碼,在 /data/mysql8_data/mysql/mysql.log 查看

    mysql -u root -p
    

說明

  • 登錄后進入 MySQL 命令行

    image-20211125014331798

  • 以下報錯,說明 MySQL 服務沒開啟

    ERROR 2002 (HY000): Can't connect to local MySQL server through socket '/tmp/mysql.sock' (2)

3.4、修改密碼

3.4.1、首次修改

MySQL 初始化的 root 用戶、新創建的用戶,都需要設置首次密碼。

建議使用本地密碼插件 mysql_native_password

# 修改密碼
ALTER USER 'root'@'localhost' IDENTIFIED WITH mysql_native_password BY '新密碼';

# 刷新權限
FLUSH PRIVILEGES;

3.4.2、平時修改

可在 Linux 或 MySQL 中修改。

  1. Linux 命令行

    mysqladmin -u用戶名 -p舊密碼 password 新密碼
    
  2. MySQL 命令行

    # 設置密碼
    SET PASSWORD FOR '用戶名'@'主機' = PASSWORD(‘密碼');
    
    # 刷新權限
    FLUSH PRIVILEGES;
    

3.5、退出、關閉服務

在 MySQL 命令行中執行

若在 Linux 命令行中,會退出/關閉 Linux 服務器。

  1. 退出 MySQL(命令行)

    quit;
    exit;
    
  2. 關閉 MySQL 服務

    shutdown;
    

4、遠程連接 MySQL(❗)

4.1、創建遠程連接用戶(❗)

  1. 選擇 mysql 數據庫,查看當前用戶

    USE mysql;
    
    SELECT user,host,plugin,authentication_string FROM user;
    
  2. host 字段 表示可訪問當前數據庫的主機,目前僅本地可訪問。

    image-20211125020858741

  3. 創建用戶,任意遠程訪問

    # 創建用戶
    CREATE user 'root'@'%';
    
    # 設置首次密碼
    ALTER USER 'root'@'%' IDENTIFIED WITH mysql_native_password BY '密碼';
    
    # 授權用戶所有權限,刷新權限
    GRANT ALL PRIVILEGES ON *.* TO 'root'@'%';
    FLUSH PRIVILEGES;
    
  4. 查看用戶:已創建一個可被任意遠程主機訪問的 root 用戶。

    image-20211125021328155

4.2、遠程連接 MySQL

以 Navicat 可視化工具為例

  1. 啟動 MySQL 服務(本文 4.1.1)

    image-20220510132315846

  2. 開放端口:默認端口號 3306

    • 查看端口狀態:no 表示未開啟

      firewall-cmd --query-port=3306/tcp
      
    • 永久開放端口

      firewall-cmd --add-port=3306/tcp --permanent
      
    • 重啟防火牆

      systemctl restart firewalld
      
  3. 遠程連接

    image-20211125125925196

TODO:遠程連接報錯 1045 分析。

完結撒花 🌹

Linux 中還可以設置 MySQL 開機自啟,本文不做介紹。


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM