用戶想要與MySQL服務器建立一條安全連接時,常常依賴VPN隧道或SSH隧道。不過,獲得MySQL連接的另一個辦法是,啟用MySQL服務器上的SSL封裝器(SSL wrapper)。這每一種方法各有其優(yōu)缺點。比如說,在出現多條短時間MySQL連接的高度動態(tài)環(huán)境下,VPN或SSH隧道也許是比SSL更好的選擇,因為后者建立每條連接時需要成本高昂的SSL握手計算。另一方面,如果是長時間運行的MySQL連接比較少的那些應用,基于SSL的加密可能很合理。由于MySQL服務器已經內置了SSL支持功能,你不需要實施VPN或SSH隧道之類單獨的安全層,這種隧道有其自己的維護開銷。
成都創(chuàng)新互聯(lián)公司是一家專業(yè)提供播州企業(yè)網站建設,專注與成都網站制作、做網站、H5建站、小程序制作等業(yè)務。10年已為播州眾多企業(yè)、政府機構等服務。創(chuàng)新互聯(lián)專業(yè)的建站公司優(yōu)惠進行中。
在MySQL服務器中實施SSL可以加密在服務器與客戶機之間來回傳輸的所有數據,因而防止廣域網或數據中心里面可能出現的竊聽或數據嗅探行為。此外,SSL還通過SSL證書提供了身份驗證機制,因而可以保護用戶,遠離可能出現的網絡釣魚攻擊。
我們在本文中將介紹如何啟用MySQL服務器上的SSL。請注意:同樣過程適用于MariaDB服務器。
創(chuàng)建Server SSL證書和私鑰
我們必須為MySQL服務器創(chuàng)建SSL證書和私鑰,通過SSL連接到服務器時要用到它們。
首先,創(chuàng)建一個臨時的工作目錄,我們將把私鑰和證書文件放在該目錄下。
$ sudo mkdir ~/cert $ cd ~/cert
確保OpenSSL已安裝在運行MySQL服務器的系統(tǒng)上。通常,所有Linux發(fā)行版在默認情況下都安裝了OpenSSL。想檢查一下OpenSSL有沒有安裝,不妨使用下面這個命令。
$ openssl version OpenSSL 1.0.1f 6 Jan 2014
現在,繼續(xù)創(chuàng)建CA私鑰和證書。下面這些命令將創(chuàng)建ca-key.pem和ca-cert.pem。
$ openssl genrsa 2048 ca-key.pem $ openssl req -sha1 -new -x509 -nodes -days 3650 -key ca-key.pem ca-cert.pem
第二個命令會詢問你幾個問題。你在這些字段里填入什么并不重要。只管填好那些字段。
下一步是為服務器創(chuàng)建私鑰。
$ openssl req -sha1 -newkey rsa:2048 -days 730 -nodes -keyout server-key.pem server-req.pem
這個命令會再次詢問幾個問題,你可以填寫上一步中提供的相同答案。
下一步,使用下面這個命令,將服務器的私鑰導出成RSA類型的密鑰。
$ openssl rsa -in server-key.pem -out server-key.pem
最后,使用CA證書,創(chuàng)建服務器證書。
$ openssl x509 -sha1 -req -in server-req.pem -days 730 -CA ca-cert.pem -CAkey ca-key.pem -set_serial 01 server-cert.pem
配置MySQL服務器上的SSL
完成上述過程后,我們應該有了CA證書、服務器的私鑰及其證書。下一步就是配置MySQL服務器,以便使用私鑰和證書。
在配置MySQL服務器之前,檢查一下SSL選項已被啟用還是被禁用。為此,登錄進入到MySQL服務器,輸入下面這個查詢。
mysql SHOW GLOBAL VARIABLES LIKE 'have_%ssl';,
該查詢的結果會如同下圖。
請注意:“have_openssl”和“have_ssl”變量的默認值是“被禁用”,如下所示。想啟用MySQL服務器中的SSL,繼續(xù)執(zhí)行下列步驟。
1. 將ca-cert.pem、server-cert.pem和server-key.pem拷貝或移動到/etc目錄下。
$ sudo mkdir /etc/mysql-ssl $ sudo cp ca-cert.pem server-cert.pem server-key.pem /etc/mysql-ssl
2. 使用文本編輯工具,打開服務器的my點吸煙 f配置文件。添加或去掉注釋[mysqld]部分中類似下面內容的幾行。這些應該指向你放在/etc/mysql-ssl中的私鑰和證書。
[mysqld] ssl-ca=/etc/mysql-ssl/ca-cert.pem ssl-cert=/etc/mysql-ssl/server-cert.pem ssl-key=/etc/mysql-ssl/server-key.pem
3. 在my點吸煙 f中,還要找到“bind-address = 127.0.0.1”,并將它改成:
bind-address = *
那樣一來,你就可以從另一個主機連接到MySQL服務器了。
4. 重啟MySQL服務。
$ sudo service mysql restart 或 $ sudo systemctl restart mysql 或 $ sudo /etc/init.d/mysql restart
你只要查看MySQL錯誤日志文件(比如/var/log/mysql/mysql.log),就可以檢查SSL配置有沒有問題。要是錯誤日志中沒有警告或錯誤(就像下面的屏幕截圖),這表明SSL配置沒有問題。
驗證SSL配置的另一個辦法就是,在MySQL服務器里面再次運行“have_%ssl”查詢。
mysql SHOW GLOBAL VARIABLES LIKE 'have_%ssl';
創(chuàng)建擁有SSL權限的用戶
服務器端的SSL配置完成后,下一步就是創(chuàng)建有權通過SSL訪問MySQL服務器的用戶。為此,登錄進入到MySQL服務器,輸入下面內容:
mysql GRANT ALL PRIVILEGES ON *.* TO ‘ssluser’@’%’ IDENTIFIED BY ‘dingdong’ REQUIRE SSL; mysql FLUSH PRIVILEGES;
把“ssluser”(用戶名)和“dingdong”(密碼)換成你自己的用戶名和密碼。
如果你想分配一個特定的IP地址(比如192.168.2.8),以便用戶從該地址來訪問服務器,那就改而使用下列查詢。
mysql GRANT ALL PRIVILEGES ON *.* TO ‘ssluser’@’192.168.2.8’ IDENTIFIED BY 'dingdong' REQUIRE SSL; mysql FLUSH PRIVILEGES;
配置MySQL客戶機上的SSL
鑒于MySQL服務器端配置已完成,不妨將目光轉移到客戶機端。就MySQL客戶機而言,我們就需要基于服務器的CA私鑰和證書,創(chuàng)建新的私鑰和證書。
在服務器的CA私鑰和證書駐留于其中的MySQL服務器主機上運行下列命令。
$ openssl req -sha1 -newkey rsa:2048 -days 730 -nodes -keyout client-key.pem client-req.pem
類似服務器端配置,上述命令會詢問幾個問題。只管填好字段,就像前面所做的那樣。
我們還需要將創(chuàng)建的客戶機私鑰轉換成RSA類型,如下所示。
$ openssl rsa -in client-key.pem -out client-key.pem,
最后,我們需要使用服務器的CA私鑰和證書,創(chuàng)建客戶機證書。
$ openssl x509 -sha1 -req -in client-req.pem -days 730 -CA ca-cert.pem -CAkey ca-key.pem -set_serial 01 client-cert.pem
現在,將ca-cert.pem、client-cert.pem和client-key.pem文件轉移到你想要運行MySQL客戶機的任何主機上。
在客戶機主機上,使用下面這個命令,通過SSL連接到MySQL服務器。
$ mysql --ssl-ca=ca-cert.pem --ssl-cert=client-cert.pem --ssl-key=client-key.pem -h -u ssluser -p
在輸入ssluser的密碼后,你會看到如往常那樣的MySQL提示符。
想檢查一下你有沒有使用SSL,在提示符處輸入狀態(tài)命令。
mysql status;
如果你已通過SSL連接上去,它會在SSL字段顯示密碼信息,如下所示。
mysql連接可分為socket連接和TCP|IP連接兩種。
[root@localhost bin]# mysql -uroot -p123456 -S/tmp/mysql.sock
-S/tmp/mysql.sock可以省略,因為默認參數如下:
假如sock文件另有其它,那么就后面不能省略,需要指定下。
mysql -h127.0.0.1 -P3306 -uroot -p123456
那么問題來了,如何知道當前連接的連接方式?
查看當前連接方式,使用\s 或者status命令
Connection: Localhost via UNIX socket 表示使用 socket 進行本地的連接
SSL: Not in use 沒有使用SSL
Connection: 127.0.0.1 via TCP/IP 使用TCP/IP 協(xié)議進行遠程連接
SSL: Cipher in use is ECDHE-RSA-AES128-GCM-SHA256 使用了SSL加密
mysql5.7默認是使用SSL的方式來進行通訊的。
/s輸出SSL: Not in use,說明當前沒有使用SSL連接。
再看下error.log有一個waning:failed to set up SSL because of the following SSL liberary error:SSL context is not usable withut certificate and private key。公密鑰文件不存在,所以無法啟用SSL的連接方式。
1、進入bin目錄執(zhí)行命令: mysql_ssl_rsa_setup 在/data 根目錄 生成相關的*.pem 密鑰文件。
2、對新生成到pem文件授權chown mysql:mysql *.pem
3、 /etc/init.d/mysqld restart 重啟mysql
4、進入命令客戶端執(zhí)行\(zhòng)s
使用IP/TCP遠程連接時,\s輸出 SSL: Cipher in use is ECDHE-RSA-AES128-GCM-SHA256。說明已經用上SSL加密。
使用socket進行本地連接,就不會使用SSL加密。\s輸出SSL: Not in use;
因為SSL開啟可能有性能影響。如果不希望使用ssl加密登錄連接,那么可以使用下面命令進行禁用:mysql -h127.0.0.1 -uroot -p123456 --ssl-mode=DISABLED
強制一個用戶使用ssl
之后david用戶就必須使用ssl登錄了,否則報錯如下:
取消一個用戶強制使用ssl
x509認證在開啟SSL的基礎下,還強制指定用戶必須使用client-cert.pem和client-key.pem證書、密鑰文件來登錄,否則登錄不了。x509是mysql最高等級的認證機制。
之前已經在data根目錄生成了8個 *.pem文件
把其中client-cert.pem和client-key.pem導出
如下,再使用之前的命令登錄。發(fā)現登錄不了了。
此時想要登錄必須在客戶端指定SSL CERT File和SSL Key File 如下在navicat中
在mysql workbench中
說明:pem配置文件中在test目錄下有,但是最好自己生成
/home/mysql/mysql-5.5.35-linux2.6-x86_64/mysql-test/std_data
/etc/init.d/mysqld restart
SHOW VARIABLES LIKE 'have_%ssl';
SHOW VARIABLES LIKE '%ssl%';
如果為yes,表示服務端已經開啟SSL
查看服務ssl等狀態(tài)
SHOW STATUS LIKE 'Ssl_cipher';
STATUS或者\s
SSL: Cipher in use is DHE-RSA-AES256-SHA表示客戶端已經 使用SSL連接
客戶端無SSL登陸:
客戶端開啟SSL登陸:
GRANT ALL PRIVILEGES ON . TO 'ssluser'@'%' IDENTIFIED BY 'zdh1234' REQUIRE SSL;
本機登陸需要單獨新增localhost
GRANT ALL PRIVILEGES ON . TO 'ssluser'@'localhost' IDENTIFIED BY 'zdh1234' REQUIRE SSL;
查看用戶:
select host,user,password from mysql.user;
修改密碼,需要重啟mysql:
客戶端無SSL登陸:
返回錯誤:ERROR 1045 (28000): Access denied for user 'ssluser'@'localhost' (using password: YES)
客戶端開啟SSL登陸:
如果不填密碼或者--ssl-ca都無法登陸
由于創(chuàng)建server使用的服務器域名為zdh-11
校驗失敗,無法登陸:
校驗成功,可以登陸: