基于 Linux 的?
CentOS 7
?安裝?MySQL 8
,包含以下步驟
- 安裝工作:卸載 MariaDB,下載資源包,檢查舊版本 MySQL,解壓安裝。
- 配置工作:基本設(shè)置,創(chuàng)建用戶組和用戶,數(shù)據(jù)目錄。
- 初始化 MySQL:配置文件,初始化。
- 啟動(dòng) MySQL:?jiǎn)?dòng)服務(wù),登錄,修改密碼,創(chuàng)建遠(yuǎn)程連接用戶,退出和關(guān)閉。
1、安裝工作
1.1、卸載 MariaDB(?)
1.1.1、MariaDB
MySQL 的一個(gè)分支,主要由開(kāi)源社區(qū)維護(hù)。
?
-
CentOS 7+
?不再默認(rèn)使用 MySQL 數(shù)據(jù)庫(kù),而是 MariaDB 數(shù)據(jù)庫(kù)。 - 直接安裝 MySQL 會(huì)與 MariaDB 的文件沖突。
???安裝 MySQL 之前,先卸載自帶的 MariaDB。
1.1.2、卸載
步驟
-
查看版本:有則需要卸載。
rpm -qa|grep mariadb
-
卸載:復(fù)制文件名,執(zhí)行以下指令。
rpm -e --nodeps 文件名
-
確認(rèn)卸載:
rpm -qa|grep mariadb
圖示
1.2、下載資源包
Hint:將 MySQL 資源包放在?
/usr/local/
?下
2 種下載方式:
1.2.1、官網(wǎng)下載
-
官網(wǎng)下載:
Linux - Generic (glibc 2.12) (x86, 64-bit)
-
上傳到服務(wù)器:
/usr/local/
?目錄下。
1.2.2、wget 下載
-
wget 指令:在?
/usr/local/
?下執(zhí)行,下載資源包。# 格式:wget 資源地址 wget https://dev.mysql.com/get/Downloads/MySQL-8.0/mysql-8.0.20-linux-glibc2.12-x86_64.tar.xz
-
1.3、檢查舊版本 MySQL
指令:
rpm -qa|grep mysql
-
沒(méi)有輸出:說(shuō)明當(dāng)前系統(tǒng)沒(méi)有安裝 MySQL,開(kāi)始安裝。
-
有輸出:顯示的 MySQL 不是想要的版本,則卸載。
# 停止服務(wù) systemctl stop mysqld # 卸載 rpm -e --nodeps mysql文件名
1.4、解壓安裝
解壓安裝
-
解壓:tar 指令。
# .tar.gz 后綴 tar -zxvf 文件名 # .tar.xz 后綴 tar -Jxvf 文件名
-
解壓完成:
/usr/local/
?下會(huì)生成?MySQL 文件夾。
Hint:將 MySQL 安裝在?
/usr/local/
?下若沒(méi)有安裝在該目錄下,通過(guò)?
mv
?指令移動(dòng)到該目錄。
2、配置工作(?)
2.1、基本設(shè)置
安裝完成后的基本設(shè)置。
2.1.1、文件夾重命名
-
重命名?MySQL 文件夾(或創(chuàng)建軟鏈接???文件管理 2.5)
-
通常命名為?
mysql版本號(hào)
# 重命名(也可通過(guò)Xftp修改) mv 原文件夾名 mysql8 # 軟鏈接 ln -s 文件夾名 mysql8
2.1.2、PATH 變量(?)
添加 PATH 變量后,可在全局使用 MySQL
添加方式:
-
臨時(shí)生效:export 命令(連接會(huì)話關(guān)閉后失效,通常用于測(cè)試環(huán)境)
export PATH=$PATH:/usr/local/mysql8/bin
-
永久生效:修改配置文件。
2.1.3、確認(rèn)安裝
-
查看版本
-
mysql --version
-
?
-
-
確定 MySQL 安裝成功后,可刪除壓縮包。
rm -rf 壓縮包名
2.2、創(chuàng)建用戶組、用戶(?)
注:需要進(jìn)入?
/usr/local
-
創(chuàng)建用戶組:
groupadd
-
創(chuàng)建用戶:
useradd
(-r
?創(chuàng)建系統(tǒng)用戶,-g
?指定用戶組)groupadd mysql useradd -r -g mysql mysql
2.3、數(shù)據(jù)目錄(?)
-
創(chuàng)建目錄:
mkdir -p /data/mysql8_data
-
賦予權(quán)限:
# 更改屬主和數(shù)組 chown -R mysql:mysql /data/mysql8_data # 更改模式 chmod -R 750 /data/mysql8_data
3、初始化 & 啟動(dòng)(?)
3.1、配置文件
在?
/usr/local/etc/
?下創(chuàng)建?my.cnf
?配置文件用于初始化 MySQL 數(shù)據(jù)庫(kù)
3.1.1、配置方式
注:部分配置涉及 MySQL 文件夾名稱,若文件夾名不是?
mysql8
?則需修改。
-
在本地創(chuàng)建后,通過(guò) Xftp 上傳
-
使用?Vim 編輯器?進(jìn)行編輯
-
進(jìn)入 Vim 編輯器
vim /usr/local/etc/my.cnf
-
按?
i
?進(jìn)入輸入模式,粘貼以下配置。 -
按?
ESC
?退出編輯模式,按?:wq
?保存并退出。
-
3.1.2、配置內(nèi)容(?)
[mysql]
# 默認(rèn)字符集
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
# 數(shù)據(jù)存放目錄
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
# 日志及進(jìn)程數(shù)據(jù)的存放目錄
log-error =/data/mysql8_data/mysql/mysql.log
pid-file =/data/mysql8_data/mysql/mysql.pid
# 服務(wù)端字符集
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
# 創(chuàng)建表時(shí)使用的默認(rèn)存儲(chǔ)引擎
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:需要進(jìn)入?
/usr/local/mysql/bin
,若添加了 PATH 變量可忽略。
初始化命令:注意文件夾名稱。
-
--defaults-file
:指定配置文件(要放在--initialize 前面) -
--user
: 指定用戶 -
--basedir
:指定安裝目錄 -
--datadir
:指定初始化數(shù)據(jù)目錄 -
--intialize-insecure
:初始化無(wú)密碼(否則生成隨機(jī)密碼)mysqld --defaults-file=/usr/local/etc/my.cnf --basedir=/usr/local/mysql8 --datadir=/data/mysql8_data/mysql --user=mysql --initialize-insecure
3.3、啟動(dòng) MySQL
查看 MySQL 的?
/bin
?下是否包含?mysqld_safe
用于后臺(tái)安全啟動(dòng) MySQL
3.3.1、啟動(dòng)服務(wù)
-
安全后臺(tái)啟動(dòng) MySQL
-
# 完整命令 /usr/local/mysql8/bin/mysqld_safe --defaults-file=/usr/local/etc/my.cnf & # 若添加了PATH變量,可省略如下 mysqld_safe --defaults-file=/usr/local/etc/my.cnf &
-
-
-
確認(rèn)啟動(dòng):第二條即 MySQL 服務(wù)。
-
ps -ef|grep mysql
-
-
3.3.2、登錄
-
無(wú)密碼:若以?
--initialize-insecure
?初始化,首次登錄時(shí)跳過(guò)密碼。mysql -u root --skip-password
-
有密碼:若初始化時(shí)設(shè)置了隨機(jī)密碼,在?
/data/mysql8_data/mysql/mysql.log
?查看mysql -u root -p
說(shuō)明
-
登錄后進(jìn)入 MySQL 命令行
?
-
以下報(bào)錯(cuò),說(shuō)明 MySQL 服務(wù)沒(méi)開(kāi)啟
ERROR 2002 (HY000): Can't connect to local MySQL server through socket '/tmp/mysql.sock' (2)
3.4、修改密碼
3.4.1、首次修改
MySQL?初始化的 root 用戶、新創(chuàng)建的用戶,都需要設(shè)置首次密碼。
建議使用本地密碼插件?
mysql_native_password
。
# 修改密碼
ALTER USER 'root'@'localhost' IDENTIFIED WITH mysql_native_password BY '新密碼';
# 刷新權(quán)限
FLUSH PRIVILEGES;
3.4.2、平時(shí)修改
可在 Linux 或 MySQL 中修改。
-
Linux 命令行
mysqladmin -u用戶名 -p舊密碼 password 新密碼
-
MySQL 命令行
# 設(shè)置密碼 SET PASSWORD FOR '用戶名'@'主機(jī)' = PASSWORD(‘密碼'); # 刷新權(quán)限 FLUSH PRIVILEGES;
3.5、退出、關(guān)閉服務(wù)
在 MySQL 命令行中執(zhí)行
若在 Linux 命令行中,會(huì)退出/關(guān)閉 Linux 服務(wù)器。
-
退出 MySQL(命令行):
quit; exit;
-
關(guān)閉 MySQL 服務(wù):
shutdown;
4、遠(yuǎn)程連接 MySQL(?)
4.1、創(chuàng)建遠(yuǎn)程連接用戶(?)
-
選擇 mysql 數(shù)據(jù)庫(kù),查看當(dāng)前用戶
USE mysql; SELECT user,host,plugin,authentication_string FROM user;
-
host 字段
?表示可訪問(wèn)當(dāng)前數(shù)據(jù)庫(kù)的主機(jī),目前僅本地可訪問(wèn)。 -
創(chuàng)建用戶,任意遠(yuǎn)程訪問(wèn)
# 創(chuàng)建用戶 CREATE user 'root'@'%'; # 設(shè)置首次密碼 ALTER USER 'root'@'%' IDENTIFIED WITH mysql_native_password BY '密碼'; # 授權(quán)用戶所有權(quán)限,刷新權(quán)限 GRANT ALL PRIVILEGES ON *.* TO 'root'@'%'; FLUSH PRIVILEGES;
-
查看用戶:已創(chuàng)建一個(gè)可被任意遠(yuǎn)程主機(jī)訪問(wèn)的 root 用戶。
?
4.2、遠(yuǎn)程連接 MySQL
以 Navicat 可視化工具為例
-
啟動(dòng) MySQL 服務(wù)(本文 4.1.1)
-
開(kāi)放端口:默認(rèn)端口號(hào) 3306
-
查看端口狀態(tài):no 表示未開(kāi)啟
firewall-cmd --query-port=3306/tcp
-
永久開(kāi)放端口:
firewall-cmd --add-port=3306/tcp --permanent
-
重啟防火墻:
systemctl restart firewalld
-
-
遠(yuǎn)程連接:
TODO:遠(yuǎn)程連接報(bào)錯(cuò) 1045 分析。
完結(jié)撒花 ??文章來(lái)源:http://www.zghlxwxcb.cn/news/detail-708795.html
Linux 中還可以設(shè)置 MySQL 開(kāi)機(jī)自啟,本文不做介紹。文章來(lái)源地址http://www.zghlxwxcb.cn/news/detail-708795.html
到了這里,關(guān)于基于 Linux 的 CentOS 7 安裝 MySQL 8,包含以下步驟的文章就介紹完了。如果您還想了解更多內(nèi)容,請(qǐng)?jiān)谟疑辖撬阉鱐OY模板網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章,希望大家以后多多支持TOY模板網(wǎng)!