婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > MySQL 使用 SSL 連接配置詳解

MySQL 使用 SSL 連接配置詳解

熱門標簽:南通電銷外呼系統哪家強 地圖簡圖標注 桂林云電銷機器人收費 清遠申請400電話 手機外呼系統違法嗎 東莞外呼企業管理系統 如何選擇優質的外呼系統 谷歌地圖標注位置圖解 沈陽智能外呼系統供應商

查看是否支持 SSL

首先在 MySQL 上執行如下命令, 查詢是否 MySQL 支持 SSL:

mysql> SHOW VARIABLES LIKE 'have_ssl';
+---------------+-------+
| Variable_name | Value |
+---------------+-------+
| have_ssl   | YES  |
+---------------+-------+
1 row in set (0.02 sec)

當 have_ssl 為 YES 時, 表示此時 MySQL 服務已經支持 SSL 了. 如果是 DESABLE, 則需要在啟動 MySQL 服務時, 使能 SSL 功能.

使用 OpenSSL 創建 SSL 證書和私鑰

首先我們需要使用 openssl 來創建服務器端的證書和私鑰. 我使用的 openssl 版本為:

>>> /usr/local/Cellar/openssl/1.0.2j/bin/openssl version
OpenSSL 1.0.2j 26 Sep 2016

新建一個 ~/temp/cert 目錄, 用于存放生成的證書和私鑰

mkdir ~/temp/cert
cd ~/temp/cert

創建 CA 私鑰和 CA 證書

然后, 我們先來生成一個 CA 私鑰:

openssl genrsa 2048 > ca-key.pem

當有了一個 CA 私鑰, 我們接下來就可以使用這個私鑰生成一個新的數字證書:

openssl req -sha1 -new -x509 -nodes -days 3650 -key ca-key.pem > ca-cert.pem

執行這個命令時, 會需要填寫一些問題, 隨便填寫就可以了. 例如:

>>> openssl req -sha1 -new -x509 -nodes -days 3650 -key ca-key.pem > ca-cert.pem

You are about to be asked to enter information that will be incorporated
into your certificate request.
What you are about to enter is what is called a Distinguished Name or a DN.
There are quite a few fields but you can leave some blank
For some fields there will be a default value,
If you enter '.', the field will be left blank.
-----
Country Name (2 letter code) [AU]:CN
State or Province Name (full name) [Some-State]:Beijing
Locality Name (eg, city) []:Beijing
Organization Name (eg, company) [Internet Widgits Pty Ltd]:xys
Organizational Unit Name (eg, section) []:xys
Common Name (e.g. server FQDN or YOUR name) []:xys
Email Address []:yongshun1228@gmail.com

執行上述命令后, 我們就有了一個 CA 私鑰和一個 CA 證書.

創建服務器端的 RSA 私鑰和數字證書

接著, 我們需要創建服務器端的私鑰和一個證書請求文件, 命令如下:

openssl req -sha1 -newkey rsa:2048 -days 3650 -nodes -keyout server-key.pem > server-req.pem

上面這個命令會生成一個新的私鑰(server-key.pem), 同時會使用這個新私鑰來生成一個證書請求文件(server-req.pem).
上面這個命令同樣需要回答幾個問題, 隨便填寫即可. 不過需要注意的是, A challenge password 這一項需要為空.
即:

>>> openssl req -sha1 -newkey rsa:2048 -days 3650 -nodes -keyout server-key.pem > server-req.pem

Generating a 2048 bit RSA private key
.................+++
..+++
writing new private key to 'server-key.pem'
-----
You are about to be asked to enter information that will be incorporated
into your certificate request.
What you are about to enter is what is called a Distinguished Name or a DN.
There are quite a few fields but you can leave some blank
For some fields there will be a default value,
If you enter '.', the field will be left blank.
-----
Country Name (2 letter code) [AU]:CN
State or Province Name (full name) [Some-State]:Beijing
Locality Name (eg, city) []:Beijing
Organization Name (eg, company) [Internet Widgits Pty Ltd]:xys
Organizational Unit Name (eg, section) []:xys
Common Name (e.g. server FQDN or YOUR name) []:xys
Email Address []:yongshun1228@gmail.com

Please enter the following 'extra' attributes
to be sent with your certificate request
A challenge password []:
An optional company name []:

下一步, 我們需要將生成的私鑰轉換為 RSA 私鑰文件格式:

openssl rsa -in server-key.pem -out server-key.pem

最后一步, 我們需要使用原先生成的 CA 證書來生成一個服務器端的數字證書:

openssl x509 -sha1 -req -in server-req.pem -days 3650 -CA ca-cert.pem -CAkey ca-key.pem -set_serial 01 > server-cert.pem

上面的命令會創建以服務器端的數字證書文件.

創建客戶端的 RSA 私鑰和數字證書

和服務器端所執行的命令類似, 我們也需要為客戶端生成一個私鑰和證書請求文件, 命令如下:

openssl req -sha1 -newkey rsa:2048 -days 3650 -nodes -keyout client-key.pem > client-req.pem

同樣地, 我們需要將生成的私鑰轉換為 RSA 私鑰文件格式:

openssl rsa -in client-key.pem -out client-key.pem

最后, 我們也需要為客戶端創建一個數字證書:

openssl x509 -sha1 -req -in client-req.pem -days 3650 -CA ca-cert.pem -CAkey ca-key.pem -set_serial 01 > client-cert.pem

使用工具創建證書與私鑰

前面我們介紹了如何使用 OpenSSL 來創建 SSL 連接的私鑰和證書文件, 現在我們來看一個更簡單的方法.
在 MySQL 5.7 中, 提供了一個名為 mysql_ssl_rsa_setup 的工具, 通過它, 我們可以很方便地創建 SSL 連接所需要的各種文件:

mkdir ~/temp/cert
cd ~/temp/cert
mysql_ssl_rsa_setup --datadir ./

上面的命令中, --datadir 表示生成的文件的目錄.

當執行了上述命令后, 也會生成八個文件:

ca-key.pem
ca.pem
client-cert.pem
client-key.pem
private_key.pem
public_key.pem
server-cert.pem
server-key.pem

這些文件和我們使用 OpenSSL 所創建的那八個文件的作用是一樣的, 這里就不再詳述了.

SSL 配置

在前面的步驟中, 我們已經生成了8個文件, 分別是:

ca-cert.pem: CA 證書, 用于生成服務器端/客戶端的數字證書.
ca-key.pem: CA 私鑰, 用于生成服務器端/客戶端的數字證書.
server-key.pem: 服務器端的 RSA 私鑰
server-req.pem: 服務器端的證書請求文件, 用于生成服務器端的數字證書.
server-cert.pem: 服務器端的數字證書.
client-key.pem: 客戶端的 RSA 私鑰
client-req.pem: 客戶端的證書請求文件, 用于生成客戶端的數字證書.
client-cert.pem: 客戶端的數字證書.

接下來我們就需要分別配置服務器端和客戶端.

服務器端配置

服務器端需要用到三個文件, 分別是: CA 證書, 服務器端的 RSA 私鑰, 服務器端的數字證書, 我們需要在 [mysqld] 配置域下添加如下內容:

[mysqld]
ssl-ca=/etc/mysql/ca-cert.pem
ssl-cert=/etc/mysql/server-cert.pem
ssl-key=/etc/mysql/server-key.pem

接著我們還可以更改 bind-address, 使 MySQL 服務可以接收來自所有 ip 地址的客戶端, 即:

bind-address = *

當配置好后, 我們需要重啟 MySQL 服務, 使能配置.

最后一步, 我們添加一個需要使用 SSL 才可以登錄的帳號, 來驗證一下我們所配置的 SSL 是否生效:

復制代碼 代碼如下:
GRANT ALL PRIVILEGES ON *.* TO 'ssl_test'@'%' IDENTIFIED BY 'ssl_test' REQUIRE SSL;
FLUSH PRIVILEGES;

當配置好后, 使用 root 登錄 MySQL, 執行 show variables like '%ssl%' 語句會有如下輸出:

mysql> show variables like '%ssl%';
+---------------+-----------------+
| Variable_name | Value      |
+---------------+-----------------+
| have_openssl | YES       |
| have_ssl   | YES       |
| ssl_ca    | ca.pem     |
| ssl_capath  |         |
| ssl_cert   | server-cert.pem |
| ssl_cipher  |         |
| ssl_crl    |         |
| ssl_crlpath  |         |
| ssl_key    | server-key.pem |
+---------------+-----------------+
9 rows in set (0.01 sec)

客戶端配置

客戶端配置相對簡單一些. 首先我們需要拷貝 ca-cert.pem, client-cert.pem 和 client-key.pem 這三個文件到客戶端主機中, 然后我們可以執行如下命令來使用 SSL 連接 MySQL 服務:

mysql --ssl-ca=/path/to/ca-cert.pem --ssl-cert=/path/to/client-cert.pem --ssl-key=/path/to/client-key.pem -h host_name -u ssl_test -p
除了上述的使用命令行方式配置 SSL 外, 我們也可以使用配置文件的方式. 即在 ~/.my.cnf 文件中添加如下內容即可:

[client]
ssl-ca=/path/to/ca-cert.pem
ssl-cert=/path/to/client-cert.pem
ssl-key=/path/to/client-key.pem

當連接成功后, 我們執行如下指令

mysql> \s
--------------
mysql Ver 14.14 Distrib 5.7.17, for Linux (x86_64) using EditLine wrapper

Connection id:    14
Current database:
Current user:    ssl_test@172.17.0.4
SSL:      Cipher in use is DHE-RSA-AES256-SHA
Current pager:    stdout
Using outfile:    ''
Using delimiter:  ;
Server version:    5.7.17 MySQL Community Server (GPL)
Protocol version:  10
Connection:    test_db via TCP/IP
Server characterset:  latin1
Db   characterset:  latin1
Client characterset:  latin1
Conn. characterset:  latin1
TCP port:    3306
Uptime:      1 hour 2 min 9 sec

Threads: 1 Questions: 23 Slow queries: 0 Opens: 126 Flush tables: 3 Open tables: 0 Queries per second avg: 0.006
--------------

如果輸出中有 SSL: Cipher in use is DHE-RSA-AES256-SHA 之類的信息, 則表示已經使用 SSL 來連接了.

在 Docker 中使能 MySQL SSL 連接

上面我們簡單介紹了一下如果使能 MySQL SSL 連接, 那么現在我們使用 Docker 來具體的實戰一把吧!

首先拉取最新的 MySQL 鏡像:

docker pull mysql

然后需要準備一下掛載到 Docker 容器的目錄結構:

>>> cd ~/temp
>>> tree
.
├── cert
│  ├── ca-key.pem
│  ├── ca.pem
│  ├── client-cert.pem
│  ├── client-key.pem
│  ├── private_key.pem
│  ├── public_key.pem
│  ├── server-cert.pem
│  └── server-key.pem
├── config
│  └── my.cnf
└── db

3 directories, 9 files

在 temp 目錄下有三個子目錄:

cert 目錄用于存放我們先前生成的證書和私鑰信息;
config 目錄用于存放 MySQL 服務的配置文件
db 目錄是用于存放 MySQL 的數據.

下一步我們需要使用如下命令啟動 MySQL 容器:

復制代碼 代碼如下:
docker run --rm --name test_db -p 10000:3306 -e MYSQL_ROOT_PASSWORD=root -v /Users/xiongyongshun/temp/db:/var/lib/mysql -v /Users/xiongyongshun/temp/config:/etc/mysql/conf.d -v /Users/xiongyongshun/temp/cert:/etc/mysql/cert mysql:latest

我們在上面的命令中, 我們分別掛載了 cert, config, db 這三個宿主機上的目錄到 MySQL 容器中.

啟動了 MySQL 服務后, 可以先使用 root 帳號登錄 MySQL, 來檢查 MySQL 服務此時是否已經開啟了 SSL 功能:

docker run -it --link test_db:test_db --rm mysql sh -c 'exec mysql -u root -p -h test_db'

登錄成功后, 我們在 MySQL 中執行如下指令:

mysql> show variables like '%ssl%';
+---------------+---------------------------------+
| Variable_name | Value              |
+---------------+---------------------------------+
| have_openssl | YES               |
| have_ssl   | YES               |
| ssl_ca    | /etc/mysql/cert/ca-cert.pem   |
| ssl_capath  |                 |
| ssl_cert   | /etc/mysql/cert/server-cert.pem |
| ssl_cipher  |                 |
| ssl_crl    |                 |
| ssl_crlpath  |                 |
| ssl_key    | /etc/mysql/cert/server-key.pem |
+---------------+---------------------------------+
9 rows in set (0.01 sec)

有上面的輸出后, 表明此時 MySQL 服務已經使用 SSL 功能了.

接著下一步, 我們按照前面所提到的, 創建一個僅僅可以使用 SSL 登錄的帳號, 來檢驗我們的配置是否有效:

復制代碼 代碼如下:
GRANT ALL PRIVILEGES ON *.* TO 'ssl_test'@'%' IDENTIFIED BY 'ssl_test' REQUIRE SSL;
FLUSH PRIVILEGES;[code]

上面的命令創建了一個帳號名為 ssl_test, 密碼為 ssl_test, 并且不限制登錄主機 ip 的帳號.

這些都配置成功后, 我們再啟動一個 MySQL 客戶端容器:

[code]docker run -it --link test_db:test_db --rm -v /Users/xiongyongshun/temp/cert:/etc/mysql/cert mysql sh -c 'exec mysql --ssl-ca=/etc/mysql/cert/ca-cert.pem --ssl-cert=/etc/mysql/cert/client-cert.pem --ssl-key=/etc/mysql/cert/client-key.pem -h test_db -u ssl_test -p'


從上面的這個命令中我們可以看到, 啟動 MySQL 客戶端容器時, 我們掛載了宿主機的 cert 目錄到容器內的 /etc/mysql/cert 目錄, 這樣在容器中就可以訪問到 SSL 私鑰和證書文件了. 接著我們在 MySQL 客戶端命令行中, 使用 --ssl-ca, --ssl-cert, --ssl-key 這三個參數來指定 SSL 連接所需要的 CA 證書, RSA 私鑰和客戶端證書.

登錄成功后, 我們執行 s 命令:

mysql> \s
--------------
mysql Ver 14.14 Distrib 5.7.17, for Linux (x86_64) using EditLine wrapper

Connection id:    5
Current database:
Current user:    ssl_test@172.17.0.5
SSL:      Cipher in use is DHE-RSA-AES256-SHA
Current pager:    stdout
Using outfile:    ''
Using delimiter:  ;
Server version:    5.7.17 MySQL Community Server (GPL)
Protocol version:  10
Connection:    test_db via TCP/IP
Server characterset:  latin1
Db   characterset:  latin1
Client characterset:  latin1
Conn. characterset:  latin1
TCP port:    3306
Uptime:      6 min 8 sec

Threads: 2 Questions: 10 Slow queries: 0 Opens: 113 Flush tables: 1 Open tables: 106 Queries per second avg: 0.027
--------------

輸出中有 SSL: Cipher in use is DHE-RSA-AES256-SHA 信息則說明我們確實是使用了 SSL 連接的 MySQL 服務器.

您可能感興趣的文章:
  • linux系統中使用openssl實現mysql主從復制
  • 多種不同的 MySQL 的 SSL 配置
  • MySQL基于SSL協議進行主從復制的詳細操作教程
  • 多種不同的 MySQL 的 SSL 配置
  • mysql通過ssl的方式生成秘鑰具體生成步驟
  • mysql show processlist 顯示mysql查詢進程
  • 通過mysql show processlist 命令檢查mysql鎖的方法
  • processlist命令 查看mysql 線程
  • Apache、SSL、MySQL和PHP平滑無縫地安裝
  • apache+mysql+php+ssl服務器之完全安裝攻略

標簽:常德 重慶 成都 天津 內蒙古 臨沂 湖州 貴州

巨人網絡通訊聲明:本文標題《MySQL 使用 SSL 連接配置詳解》,本文關鍵詞  MySQL,使用,SSL,連接,配置,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《MySQL 使用 SSL 連接配置詳解》相關的同類信息!
  • 本頁收集關于MySQL 使用 SSL 連接配置詳解的相關信息資訊供網民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    亚洲成人777| 欧美特级限制片免费在线观看| 欧美一区二区三区免费视频| 免费观看一级欧美片| 欧美大片在线观看一区二区| 波多野结衣视频一区| 亚洲成人自拍偷拍| 日韩欧美的一区二区| 丁香婷婷综合激情五月色| 亚洲小说春色综合另类电影| 精品国产乱码91久久久久久网站| 日欧美一区二区| 中文字幕第一区综合| 4438x亚洲最大成人网| 成人看片黄a免费看在线| 五月天国产精品| 日韩欧美一区二区视频| av不卡免费在线观看| 久久精品国产澳门| 亚洲视频免费看| 久久久噜噜噜久久人人看| 欧美性一级生活| gogogo免费视频观看亚洲一| 喷水一区二区三区| 一区二区三区日韩在线观看| 久久精品视频一区| 日韩午夜三级在线| 欧美日韩精品一二三区| 91麻豆swag| 成人亚洲一区二区一| 免费不卡在线观看| 亚洲国产你懂的| 亚洲日本青草视频在线怡红院| 欧美成人精精品一区二区频| 欧美区视频在线观看| 欧美亚洲一区三区| av午夜一区麻豆| 国产不卡视频在线观看| 国产一区二区在线电影| 久久精品99国产精品日本| 免费观看成人av| 香蕉影视欧美成人| 午夜电影一区二区| 视频一区二区三区入口| 亚洲一区二区三区小说| 亚洲成人av电影在线| 亚洲国产精品v| 国产欧美视频一区二区| 国产亚洲一区二区三区| 国产午夜一区二区三区| 亚洲国产成人午夜在线一区 | 中文字幕成人在线观看| 精品国产91久久久久久久妲己 | 一区视频在线播放| 日本一区二区视频在线观看| 久久―日本道色综合久久| 久久久久亚洲综合| 国产亚洲女人久久久久毛片| 日韩免费成人网| 欧美经典一区二区三区| 亚洲视频你懂的| 中文字幕欧美三区| 亚洲精品国产精品乱码不99| 亚洲精品成人少妇| 欧美aaaaa成人免费观看视频| 久久国产生活片100| 丁香啪啪综合成人亚洲小说| 日本高清不卡aⅴ免费网站| 欧美午夜精品久久久久久孕妇| 91精品欧美久久久久久动漫| 精品日韩欧美在线| 国产精品久久久久久久久久久免费看| 亚洲免费在线观看| ...xxx性欧美| 婷婷中文字幕综合| 国产精品白丝jk白祙喷水网站| 成人精品小蝌蚪| 欧美午夜免费电影| 久久久www成人免费无遮挡大片| 亚洲少妇中出一区| 蜜桃av一区二区| 91亚洲精品乱码久久久久久蜜桃| 色欧美乱欧美15图片| 日韩小视频在线观看专区| 欧美激情一区不卡| 日韩高清中文字幕一区| 夫妻av一区二区| 91精品国产乱码久久蜜臀| 久久久99精品久久| 亚洲成人福利片| 国产精品一区二区果冻传媒| 欧美亚洲禁片免费| 中文字幕第一区二区| 日本欧美一区二区三区| 色综合亚洲欧洲| 日本一区二区免费在线| 国产成人综合在线播放| 国产亚洲精品aa| www.综合网.com| 一区二区三区资源| 欧美亚洲日本一区| 日本伊人色综合网| 欧美成人vps| 国产美女精品人人做人人爽| 国产精品视频免费看| 99久久99久久精品免费看蜜桃| 中文字幕一区二区三区四区| 在线免费观看不卡av| 午夜私人影院久久久久| 欧美精品一区二区三区在线| 国产成人精品亚洲777人妖 | 福利电影一区二区三区| 国产精品国模大尺度视频| 一本一本久久a久久精品综合麻豆 一本一道波多野结衣一区二区 | 国产精品久久久久久妇女6080 | 国产免费久久精品| 波多野结衣中文一区| 亚洲综合在线电影| 欧美岛国在线观看| 99久久er热在这里只有精品66| 一区二区三区四区中文字幕| 欧美老肥妇做.爰bbww视频| 精品影院一区二区久久久| 国产精品久久精品日日| 欧美一区二区私人影院日本| 国产白丝精品91爽爽久久| 一个色在线综合| 国产女同性恋一区二区| 欧美日韩成人激情| 高清不卡一区二区| 亚洲第一福利一区| 国产欧美日韩久久| 欧美日韩五月天| 国产宾馆实践打屁股91| 日韩精品视频网| 亚洲欧美另类在线| 久久久久久久久久久黄色| 欧美在线不卡视频| 国产99一区视频免费| 午夜精品久久一牛影视| 国产精品国产三级国产a| 56国语精品自产拍在线观看| 99久久精品国产精品久久 | 91丨porny丨首页| 精品亚洲欧美一区| 日日骚欧美日韩| 亚洲一级二级在线| 国产精品久久毛片a| 久久亚洲影视婷婷| 欧美一区二区三区四区高清| 日本丰满少妇一区二区三区| 成人av免费观看| 国产一区视频网站| 蜜臀av国产精品久久久久| 亚洲国产精品久久人人爱| 亚洲欧美日韩国产另类专区| 国产精品久久一卡二卡| 欧美国产精品专区| 久久在线免费观看| 精品国产一区二区三区av性色| 欧美丰满一区二区免费视频| 色综合色综合色综合| a在线播放不卡| 成人av电影在线| 99久久久国产精品免费蜜臀| 国产91色综合久久免费分享| 久久99精品久久久久久国产越南 | 中文字幕第一区综合| 久久亚区不卡日本| 久久久久久久久久久电影| 欧美成人乱码一区二区三区| 日韩一区二区三区三四区视频在线观看| 欧美影院精品一区| 欧美日韩一区二区在线观看| 欧美日韩精品一区视频| 欧美精品第1页| 日韩欧美高清一区| 久久日韩精品一区二区五区| 日韩美一区二区三区| 欧美不卡在线视频| 国产日韩影视精品| 中文字幕在线不卡| 一区二区三区在线观看国产| 一级中文字幕一区二区| 亚洲成人精品一区| 美女视频黄 久久| 国产九色sp调教91| 99久久亚洲一区二区三区青草 | 91美女片黄在线观看| 色综合一区二区| 欧美狂野另类xxxxoooo| 日韩视频在线永久播放| 久久婷婷国产综合精品青草| 国产精品九色蝌蚪自拍| 亚洲国产一区二区a毛片| 五月综合激情婷婷六月色窝| 久久99国产精品尤物| 国产成人综合在线播放| 在线视频一区二区三区| 日韩欧美自拍偷拍|