国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 服務(wù)器 > Web服務(wù)器 > 正文

在 CentOS 7 中安裝 MySQL 8 的教程詳解

2024-09-01 13:55:45
字體:
供稿:網(wǎng)友

準(zhǔn)備

本文環(huán)境信息:

 

軟件 版本
CentOS CentOS 7.4
MySQL 8.0.x

 

安裝前先更新系統(tǒng)所有包

sudo yum update

安裝

1. 添加 Yum 包

wget https://dev.mysql.com/get/mysql80-community-release-el7-1.noarch.rpm# 或者 wget http://repo.mysql.com/mysql80-community-release-el7-1.noarch.rpmsudo yum updatesudo rpm -ivh mysql80-community-release-el7-1.noarch.rpm

注:在 官網(wǎng) 可以找到最新的 rpm 包名。

2. 安裝 MySQL

# 安裝sudo yum -y install mysql-community-server# 啟動守護進程sudo systemctl start mysqld# 查看狀態(tài)sudo systemctl status mysqld# 查看版本mysql -V

安裝完后,MySQL 會在系統(tǒng)啟動時自動啟動,如果不想讓它自動啟動,可以使用 systemctl disable mysqld 關(guān)閉它。

3. 修改密碼

MySQL 安裝過程中會為 root 用戶生成一個臨時密碼,保存在 /var/log/mysqld.log 中。通過以下命令查看:
sudo grep 'temporary password' /var/log/mysqld.log

進入 MySQL 客戶端修改:

mysql -u root -pALTER USER 'root'@'localhost' IDENTIFIED BY 'your passowrd';# ALTER USER 'root'@ IDENTIFIED BY 'your passowrd';

密碼強度要求是:不少于12字符,必須包含大寫字母、小寫字母、數(shù)字和特殊字符。

3. MySQL 安全配置

MySQL 包含一個安全設(shè)置向?qū)?u>腳本,可以用它來修改安全選項。

sudo mysql_secure_installation

運行后依次設(shè)置以下幾項:

1.修改root賬號密碼
2.密碼強度驗證插件(建議使用)
3.移除匿名用戶(建議移除)
4.禁用root賬戶遠程登錄
5.移除測試數(shù)據(jù)庫(test)

根據(jù)個人情況設(shè)置。

用戶權(quán)限

1. 賦予權(quán)限

# 創(chuàng)建本地用戶CREATE USER 'user'@'localhost' IDENTIFIED BY 'password';# 新建遠程用戶CREATE USER 'user'@'%' IDENTIFIED BY 'password';# 新建數(shù)據(jù)庫CREATE DATABASE test_db;# 查看用戶權(quán)限SHOW GRANTS FOR 'user'@'%';# 賦予用戶指定數(shù)據(jù)庫遠程訪問權(quán)限GRANT ALL PRIVILEGES ON test_db.* TO 'user'@'%';# 賦予用戶對所有數(shù)據(jù)庫遠程訪問權(quán)限GRANT ALL PRIVILEGES ON *.* TO 'user'@'%';# 賦予用戶對所有數(shù)據(jù)庫本地訪問權(quán)限GRANT ALL PRIVILEGES ON *.* TO 'user'@'localhost';# 刷新權(quán)限FLUSH PRIVILEGES;

2. 收回權(quán)限

# 收回權(quán)限REVOKE ALL PRIVILEGES ON *.* FROM 'test'@'%';# 刪除本地用戶DROP USER 'user'@'localhost';# 刪除遠程用戶DROP USER 'user'@'%';# 刷新權(quán)限FLUSH PRIVILEGES;

3. 遠程登錄

在 mysql 數(shù)據(jù)庫查看 user 表信息 :

use mysql;select host, user, authentication_string, plugin from user;

表格中 root 用戶的 host 默認(rèn)是 localhost,只允許本地訪問。授權(quán) root 用戶的所有權(quán)限并設(shè)置遠程訪問:

# 授權(quán)GRANT ALL ON *.* TO 'root'@'%';# 刷新FLUSH PRIVILEGES;

root 用戶默認(rèn)的密碼加密方式是:caching_sha2_password;而很多圖形客戶端工具可能還不支持這種加密認(rèn)證方式,連接的時候就會報錯 。通過以下命令重新修改密碼:

ALTER USER 'root'@'%' IDENTIFIED WITH mysql_native_password BY 'your password';

這里指定了 root 的密碼加密方式為 mysql_native_password,如果想改變默認(rèn)密碼加密方式都是,可以在 /etc/my.cnf 文件加上一行:

default-authentication-plugin=mysql_native_password

如果服務(wù)器開啟了防火墻,則需要打開 3306 端口。

firewall-cmd --add-port=3306/tcp --permanentfirewall-cmd --reload

注意:如果是云服務(wù)器,有的服務(wù)商(如阿里云)需要到控制臺去開放端口的。

修改字符編碼

字符集是一套符號和編碼,查看字符集配置:

mysql> show variables like 'charac%';+--------------------------+--------------------------------+| Variable_name  | Value    |+--------------------------+--------------------------------+| character_set_client | utf8mb4   || character_set_connection | utf8mb4   || character_set_database | utf8mb4   || character_set_filesystem | binary    || character_set_results | utf8mb4   || character_set_server | utf8mb4   || character_set_system | utf8    || character_sets_dir | /usr/share/mysql-8.0/charsets/ |+--------------------------+--------------------------------+

字符集生效規(guī)則為:Table 繼承于 Database,Database 繼承于 Server。就是說,可只設(shè)置 character_set_server。

校對規(guī)則是在字符集內(nèi)用于比較字符的一套規(guī)則,查看校對規(guī)則:

mysql> show character set like 'utf8%';+---------+---------------+--------------------+--------+| Charset | Description | Default collation | Maxlen |+---------+---------------+--------------------+--------+| utf8 | UTF-8 Unicode | utf8_general_ci | 3 || utf8mb4 | UTF-8 Unicode | utf8mb4_0900_ai_ci | 4 |+---------+---------------+--------------------+--------+

校對規(guī)則生效規(guī)則:如果沒有設(shè)置校對規(guī)則,字符集取默認(rèn)校對規(guī)則,例如 utf8mb4 的校對規(guī)則是utf8mb4_0900_ai_ci。

MySQL 8 默認(rèn)字符集改成了 utf8mb4。之前的 MySQL 版本如果默認(rèn)字符集不是 utf8mb4,建議改成 utf8mb4。

mb4 即 most bytes 4。為什么是 utf8mb4,而不是 utf8?MySQL 支持的 utf8 編碼最大字符長度為 3 字節(jié),如果遇到 4 字節(jié)的寬字符就會插入異常。

下面是 老版MySQL 修改字符集為 utf8mb4 的步驟,MySQL 8.0+ 無需修改。

# 查看配置文件位置whereis my.cnf# 打開文件vi /etc/my.cnf

增加字符編碼配置項:

[client]default-character-set=utf8mb4[mysqld]character-set-server=utf8mb4collation-server=utf8mb4_general_ci

重啟 MySQL 服務(wù)

sudo systemctl restart mysqld

使用 MySQL 命令檢查字符集配置:

show variables like 'charac%';

參考

https://dev.mysql.com/doc/mysql-yum-repo-quick-guide/en/

https://ken.io/note/centos-mysql8-setup

推薦:

感興趣的朋友可以關(guān)注小編的微信公眾號【碼農(nóng)那點事兒】,更多網(wǎng)頁制作特效源碼及學(xué)習(xí)干貨哦!?。?/p>

總結(jié)

以上所述是小編給大家介紹的在 CentOS 7 中安裝 MySQL 8 的教程詳解,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復(fù)大家的。在此也非常感謝大家對VEVB武林網(wǎng)網(wǎng)站的支持!


注:相關(guān)教程知識閱讀請移步到服務(wù)器教程頻道。
發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 台南县| 常熟市| 黔西县| 车险| 辽宁省| 长沙市| 高淳县| 上栗县| 吴江市| 诏安县| 雅安市| 工布江达县| 苗栗县| 伊宁县| 务川| 陆河县| 云南省| 固始县| 阜新市| 历史| 涞水县| 宕昌县| 德兴市| 鄄城县| 福州市| 嘉定区| 乌兰察布市| 肥城市| 田阳县| 榆树市| 巴彦淖尔市| 康定县| 赣州市| 白城市| 玉门市| 克拉玛依市| 五寨县| 汉寿县| 通辽市| 丹江口市| 财经|