Mysql Centos SSL/SSH远程访问
2018-01-24 17:03
1246 查看
ps:最近在研究远程数据库的研究,直接用SSH 连接对自己还好,开发给别人就不安全了,那么用什么方式来不通过用户名密码访问远程数据库呢?在数据库连接工具中看到有SSL 连接方式、HTTP连接、SSH连接方式
SSH方式访问
SSL方式访问
SSL证书生成自签名证书
- 生成CA证书
- 服务器证书生成CA证书签名
- 客户端证书生成CA证书签名
- 验证证书
- Mysql设置SSL
- Mysql启用远程连接
创建拥有SSL权限的用户
客户端证书导出
SSL连接错误
SSH 填入服务器的ip 连接用户名,密码。
(连接工具使用 Navicat for MySQL)
通过安装软件解决
安装完成之后即可进行文件操作
生成服务器证书server-cert.pem、server-key.pem文件 生成新的证书文件,删除密码并用CA证书签名。
下图注意直接Enter跳过不输入
正确结果,否则对出错的证书重新签名
将文件权限授予 mysql,更改秘钥文件权限
备份秘钥文件
查看Mysql SSL状态
图示未开启SSL。
启用Mysql SSL连接 编辑 my.cnf文件
my.cnf添加客户端 秘钥
客户端证书导出
SSL连接错误
ERROR 2026 (HY000):
证书文件访问失败<允许被访问的目录中即可>
参考:mysql SSL连接参考
SSH方式访问
SSL方式访问
SSL证书生成自签名证书
- 生成CA证书
- 服务器证书生成CA证书签名
- 客户端证书生成CA证书签名
- 验证证书
- Mysql设置SSL
- Mysql启用远程连接
创建拥有SSL权限的用户
客户端证书导出
SSL连接错误
1.SSH方式访问
将分配的username@’%’ 数据库用户 填入 常规SSH 填入服务器的ip 连接用户名,密码。
(连接工具使用 Navicat for MySQL)
2.SSL方式访问
这里会涉及到证书的下载,那么不通过ftp,如何将远程的证书文件download 到本地呢?通过安装软件解决
# yum -y install lrzsz
安装完成之后即可进行文件操作
1.上传文件到centos 先定位到操作文件夹 # cd / #rz
从Centos拷贝文件到本地 #sz <文件名>
1.SSL证书生成(自签名证书)
定位到存储证书的位置- 生成CA证书
openssl genrsa 2048 > ca-key.pem openssl req -new -x509 -nodes -days 3600 -key ca-key.pem -out ca.pem
生成服务器证书server-cert.pem、server-key.pem文件 生成新的证书文件,删除密码并用CA证书签名。
- 服务器证书生成,CA证书签名
openssl req -newkey rsa:2048 -days 3600 -nodes -keyout server-key.pem -out server-req.pem
下图注意直接Enter跳过不输入
openssl rsa -in server-key.pem -out server-key.pem
openssl x509 -req -in server-req.pem -days 3600 -CA ca.pem -CAkey ca-key.pem -set_serial 01 -out server-cert.pem
- 客户端证书生成,CA证书签名
openssl req -newkey rsa:2048 -days 3600 -nodes -keyout client-key.pem -out client-req.pem 删除密码
RSA Key写入 openssl rsa -in client-key.pem -out client-key.pem
CA证书给客户端证书签名 openssl x509 -req -in client-req.pem -days 3600 -CA ca.pem -CAkey ca-key.pem -set_serial 01 -out client-cert.pem
- 验证证书
用ca证书、服务器证书、客户端证书 openssl verify -CAfile ca.pem server-cert.pem client-cert.pem
正确结果,否则对出错的证书重新签名
将文件权限授予 mysql,更改秘钥文件权限
授权 chown -R mysql:mysql /etc/certs/ 更改权限 chmod 600 client-key.pem server-key.pem ca-key.pem
备份秘钥文件
mkdir -p ~/mysql-certs/ 定位到该目录,移动文件 cd /var/lib/mysql/ mv ca.pem ca-key.pem ~/mysql-certs/ mv server-key.pem server-cert.pem ~/mysql-certs/ mv client-key.pem client-cert.pem ~/mysql-certs/ mv private_key.pem public_key.pem ~/mysql-certs/
- Mysql设置SSL
重启mysql服务 systemctl restart mysqld <service mysqld restart>
查看Mysql SSL状态
SHOW GLOBAL VARIABLES LIKE '%ssl%'; status;
图示未开启SSL。
启用Mysql SSL连接 编辑 my.cnf文件
# Type your own certificates directory ssl-ca=/etc/certs/ca.pem ssl-cert=/etc/certs/server-cert.pem ssl-key=/etc/certs/server-key.pem 添加到my.cnf文件中 服务器秘钥证书
my.cnf添加客户端 秘钥
ssl-ca=/etc/certs/ca.pem ssl-cert=/etc/certs/client-cert.pem ssl-key=/etc/certs/client-key.pem
- Mysql启用远程连接
创建拥有SSL权限的用户编辑my.cnf文件 bind-address = * require_secure_transport = ON 重启服务
创建SSL登录的用户 GRANT ALL PRIVILEGES ON *.* TO 'ssl_test'@'%' IDENTIFIED BY 'ssl_test' REQUIRE SSL; FLUSH PRIVILEGES;<刷新>
通过SSL 连接mysql mysql --ssl-ca=/mysql-certs/ca.pem --ssl-cert=/mysql-certs/client-cert.pem --ssl-key=/mysql-certs/client-key.pem -h 39.106.39.106 -u ssl_test -p
客户端证书导出
# sz ca.pem # sz client-cert.pem # sz client-key.pem
SSL连接错误
ERROR 2026 (HY000):
证书文件访问失败<允许被访问的目录中即可>
SSL connection error: SSL_CTX_set_default_verify_paths failed
参考:mysql SSL连接参考
相关文章推荐
- Centos6.5 远程访问mysql
- CentOS7下安装mysql5.6修改字符集为utf8并开放端口允许远程访问
- CentOS7 下MySQL开启远程访问
- 在Centos下启用mysql的远程访问账号
- CentOS系统中安装MySQL和开启MySQL远程访问的方法
- mysql远程访问数据库(从windows访问centos的mysql数据库)
- centos下mysql开启远程访问
- centos设置mysql远程机器连接访问
- 在Centos下启用mysql的远程访问账号
- centos中安装Mysql方法以及密码修改,远程访问。
- centos7 mysql 安装及设置远程访问
- 在Centos下启用mysql的远程访问账号
- CentOS 和Windows 下配置MySQL远程访问
- centos上安装mysql并设置远程访问
- centos 5.6 mysql远程访问设置(无需密码)
- centos上安装mysql并设置远程访问的操作方法
- centos6 关于 ssh,svn,tomcat远程不能访问的问题处理过程
- MySQL workbench外网通过PuTTY设置SSH的tunnels远程访问内网服务器中的MySQL
- CentOS 设置mysql的远程访问
- centOS下mysql下载安装并授权远程访问