MySQL8開啟SSL加密方式
1 概述
MySQL從5.7開始默認開啟SSL加密功能,進入MySQL控制臺后輸入status可以查看SSL的狀態(tài),出現(xiàn)下圖表示在使用SSL:

另外,加密連接需要密鑰與證書,可以使用OpenSSL手動生成或使用mysql_ssl_rsa_setup自動生成,這里使用了mysql_ssl_rsa_setup。
下面從安裝開始。
2 安裝(可選)
系統(tǒng)CentOS,直接使用yum安裝(編譯安裝參考此處),先用list查看一下:

這里的版本是8.0.17,直接install:
yum install mysql yum install mysql-server
好了之后啟動服務:
systemctl start mysqld
然后獲取臨時密碼后修改root密碼:
grep password /var/log/mysql/mysqld.log

這里顯示密碼為空,直接root登錄修改密碼:
mysql -u root -p alter user root@localhost identified by 'xxxxx

3 生成證書與密鑰
首先查看有沒有開啟SSL,MySQL控制臺輸入
show variables like '%ssl%';

這里have_ssl顯示yes,表示已經(jīng)開啟了,表示本地的使用了SSL連接,如果顯示為no,使用MySQL自帶的工具即可開啟SSL:
mysqld_ssl_rsa_setup
然后默認在/var/lib/mysql下會有幾個pem文件,說明如下:

接著重啟服務:
systemctl restart mysqld
4 測試
進入服務器的MySQL控制臺,新建兩個測試用戶,一個使用SSL,一個不使用SSL:

然后在本機上測試,首先測試不需要SSL的用戶,輸入密碼123456后可以直接登錄:

然后測試需要SSL的用戶:

輸入密碼123456后登錄不了,使用scp從服務器復制CA證書與客戶端證書與私鑰:
scp username@xxx.xxx.xxx.xxx:/var/lib/mysql/\{ca.pem,client-key.pem,client-cert.pem} .
然后在登錄時加上
--ssl-ca=ca.pem --ssl-cert=client-cert.pem --ssl-key=client-key.pem

登錄成功。
總結
以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關文章
linux環(huán)境下安裝mysql數(shù)據(jù)庫的詳細教程
這篇文章主要介紹了linux環(huán)境下安裝mysql數(shù)據(jù)庫的詳細教程,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2020-06-06
修改mysql5.5默認編碼(圖文步驟修改為utf-8編碼)
安裝mysql后,啟動服務并登陸,使用show variables命令可查看mysql數(shù)據(jù)庫的默認編碼;mysql數(shù)據(jù)庫的默認編碼并不是utf-8如何修改呢,本文將詳細介紹,感興趣的朋友可以了解下2013-01-01

