CentOS7安裝mysql8.0.12
根據蒐集的資料安裝測試並在安裝測試過程中整理的文件,部分參考文件在相應位置有標記。如有不足希望不吝賜教。
目錄
一、配置yum源
1.下載mysql源安裝包
本次下載目錄為:/home/目錄,因此進入:cd /home
執行下載命令:
wget https://dev.mysql.com/get/mysql80-community-release-el7-1.noarch.rpm
2.安裝mysql源
下載完成後使用下面命令安裝源:
yum localinstall mysql80-community-release-el7-1.noarch.rpm
3.檢查是否安裝成功
yum repolist enabled | grep "mysql.*-community.*"
4.修改安裝版本(非必須)
如果需要安裝指定版本的mysql,可以修改/etc/yum.repos.d/mysql-community.repo源,改變預設安裝的mysql版本。
例如要安裝5.7版本,將5.7源的enabled=0改成enabled=1,將8.0的enabled=1改成enabled=0即可,如下(本次未做修改,直接安裝最新版8.0.12):
二、安裝mysql
直接使用命令:yum install mysql-community-server即可。
三、啟動mysql服務
1.啟動
systemctl start mysqld
或者
service mysqld start
2.檢視啟動狀態
systemctl status mysqld
或者
service mysqld status
3.設定開機啟動
systemctl enable mysqld
systemctl daemon-reload
四、配置及部分命令
1.修改登入密碼
mysql安裝完成之後,在/var/log/mysqld.log檔案中給root生成了一個預設密碼。通過下面的方式找到root預設密碼,然後登入mysql進行修改:
grep 'temporary password' /var/log/mysqld.log
本地MySQL客戶端登入
mysql -uroot -p
密碼是上一步查詢出來的。輸入後回車。
然後修改密碼:
ALTER USER 'root'@'localhost' IDENTIFIED BY '[email protected]';
或者
set password for 'root'@'localhost'=password('[email protected]');
注意:mysql5.7預設安裝了密碼安全檢查外掛(validate_password),預設密碼檢查策略要求密碼必須包含:大小寫字母、數字和特殊符號,並且長度不能少於8位。否則會提示ERROR 1819 (HY000): Your password does not satisfy the current policy requirements錯誤,如下圖所示:
通過msyql環境變數可以檢視密碼策略的相關資訊(執行這一步需要先修改預設密碼,即執行完上一步修改才可以,否則會報錯:ERROR 1820 (HY000): You must reset your password using ALTER USER statement before executing this statement.):
show variables like '%password%';
validate_password_policy:密碼策略,預設為MEDIUM策略
validate_password_dictionary_file:密碼策略檔案,策略為STRONG才需要
validate_password_length:密碼最少長度
validate_password_mixed_case_count:大小寫字元長度,至少1個
validate_password_number_count :數字至少1個
validate_password_special_char_count:特殊字元至少1個
上述引數是預設策略MEDIUM的密碼檢查規則。
修改密碼策略:
在/etc/my.cnf檔案新增validate_password_policy配置,指定密碼策略:
選擇0(LOW),1(MEDIUM),2(STRONG)其中一種,選擇2需要提供密碼字典檔案。
validate_password_policy=0
如果不需要密碼策略,新增my.cnf檔案中新增如下配置禁用即可:
validate_password = off
重新啟動mysql服務使配置生效:systemctl restart mysqld
2.新增遠端登入使用者
預設只允許root帳戶在本地登入,如果要在其它機器上連線mysql,必須修改root允許遠端連線,或者新增一個允許遠端連線的帳戶。
修改root使用者遠端訪問許可權:
選擇 mysql 資料庫:use mysql;
在 mysql 資料庫的 user 表中檢視當前 root 使用者的相關資訊:
select host, user from user;
查看錶格中 root 使用者的 host,預設應該顯示的 localhost,只支援本地訪問,不允許遠端訪問。
授權 root 使用者的所有許可權並設定遠端訪問
GRANT ALL ON *.* TO 'root'@'%';
如果報錯:ERROR 1410 (42000): You are not allowed to create a user with GRANT
則使用:
update user set host='%' where user ='root';
然後使用下面命令使修改生效:
flush privileges;
如有需要再執行之前授權報錯的命令即可成功,最後同樣使用flush privileges;命令重新整理。
3.sqlyog連結時出現2058異常
完成上面的配置使用sqlyog連結時會出現2058的異常,此時我們需要修改mysql,命令列登入mysql(與修改密碼中登入相同,使用修改後的密碼),然後執行下面的命令:
ALTER USER 'root'@'localhost' IDENTIFIED WITH mysql_native_password BY 'password';
其中password為自己修改的密碼。然後SQLyog中重新連線,則可連線成功,OK。
如果報錯:ERROR 1396 (HY000): Operation ALTER USER failed for 'root'@'localhost'則使用下面命令:
ALTER USER 'root'@'%' IDENTIFIED WITH mysql_native_password BY 'password';
4.修改預設編碼方式
mysql8.0預設編碼方式為utf8mb4,因此使用時不需要修改,可使用如下命令檢視:
SHOW VARIABLES WHERE Variable_name LIKE 'character_set_%' OR Variable_name LIKE 'collation%';
如果需要修改其他編碼方式,方法有很多,以下僅為舉例。
比如需要修改為utf8mb4,可以使用如下方式:
修改mysql配置檔案my.cnf(windows為my.ini)
my.cnf一般在etc/mysql/my.cnf位置。找到後請在以下三部分裡新增如下內容:
[client]
default-character-set = utf8mb4
[mysql]
default-character-set = utf8mb4
[mysqld]
character-set-client-handshake = FALSE
character-set-server = utf8mb4
collation-server = utf8mb4_unicode_ci
init_connect='SET NAMES utf8mb4'
重啟mysql即可。
collation_connection 、collation_database 、collation_server是什麼沒關係。但必須保證以下這幾個變數必須是utf8mb4。:
- character_set_client (客戶端來源資料使用的字符集)
- character_set_connection (連線層字符集)
- character_set_database (當前選中資料庫的預設字符集)
- character_set_results (查詢結果字符集)
- character_set_server (預設的內部操作字符集)
資料庫連線引數中:
characterEncoding=utf8會被自動識別為utf8mb4,也可以不加這個引數,會自動檢測。
而autoReconnect=true是必須加上的。
5.部分引數配置查詢命令
#查詢mysql最大連線數設定
show global variables like 'max_conn%';
SELECT @@MAX_CONNECTIONS AS 'Max Connections';
# 檢視最大連結數
show global status like 'Max_used_connections';
# 檢視慢查詢日誌是否開啟以及日誌位置
show variables like 'slow_query%';
# 檢視慢查詢日誌超時記錄時間
show variables like 'long_query_time';
# 檢視連結建立以及現在正在連結數
show status like 'Threads%';
# 檢視資料庫當前連結
show processlist;
# 檢視資料庫配置
show variables like '%quer%';
五、徹底解除安裝mysql
1.解除安裝軟體
yum remove mysql-community-server
完成後使用rpm -qa|grep mysql命令檢視,如果有查詢結果,則使用yum remove 名稱清理掉。如圖:
再使用命令rpm -qa | grep -i mysql檢視,如果有結果使用rpm -e 名稱解除安裝。例如:
2.刪除檔案
rm -rf /var/lib/mysql
rm /etc/my.cnf
rm -rf /usr/share/mysql-8.0
如果需要重新安裝,在安裝完成啟動之前可以先對mysql目錄賦予許可權防止異常發生:
chmod -R 777 /var/lib/mysql
END