MySQL8开启SSL加密方式

 更新时间:2025年11月20日 10:10:05   作者:氷泠  
本文介绍了如何在MySQL 5.7及以上版本中启用SSL加密,并详细描述了安装、生成证书与密钥、测试SSL连接的步骤,通过这些步骤,可以确保MySQL连接的安全性

1 概述

MySQL5.7开始默认开启SSL加密功能,进入MySQL控制台后输入status可以查看SSL的状态,出现下图表示在使用SSL

另外,加密连接需要密钥与证书,可以使用OpenSSL手动生成或使用mysql_ssl_rsa_setup自动生成,这里使用了mysql_ssl_rsa_setup

下面从安装开始。

2 安装(可选)

系统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 生成证书与密钥

首先查看有没有开启SSLMySQL控制台输入

show variables like '%ssl%';

这里have_ssl显示yes,表示已经开启了,表示本地的使用了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

登录成功。

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

您可能感兴趣的文章:

相关文章

  • MySql学习day03:数据表之间的连接、查询详解

    MySql学习day03:数据表之间的连接、查询详解

    这篇文章主要介绍了MySql数据表之间的连接、查询,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-04-04
  • mysql 8.0.12 安装使用教程

    mysql 8.0.12 安装使用教程

    这篇文章主要为大家详细介绍了mysql 8.0.12 安装使用教程,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2018-08-08
  • mysql 单机数据库优化的一些实践

    mysql 单机数据库优化的一些实践

    这篇文章主要介绍了mysql 单机数据库优化的一些实践的相关资料,需要的朋友可以参考下
    2016-09-09
  • 解决MySQL因不能创建临时文件而导致无法启动的方法

    解决MySQL因不能创建临时文件而导致无法启动的方法

    这篇文章主要跟大家介绍了关于解决MySQL因不能创建临时文件而导致无法启动的方法,文中通过示例代码介绍了详细的解决方法,对大家具有一定的的参考学习价值,需要的朋友们下面来一起看看吧。
    2017-06-06
  • MySQL中WITH用法小结

    MySQL中WITH用法小结

    WITH子句是MySQL中的一种SQL结构,本文主要介绍了MySQL中WITH用法小结,具有一定的参考价值,感兴趣的可以了解一下
    2023-10-10
  • MySQL全局锁、表锁、行锁、间隙锁、临键锁超详细讲解

    MySQL全局锁、表锁、行锁、间隙锁、临键锁超详细讲解

    锁是计算机用以协调多个进程间并发访问同一共享资源的一种机制,MySQL中为了保证数据访问的一致性与有效性等功能,实现了锁机制,这篇文章主要介绍了MySQL全局锁、表锁、行锁、间隙锁、临键锁超详细讲解的相关资料,需要的朋友可以参考下
    2026-01-01
  • 使用FriendFeed来提升MySQL性能的方法

    使用FriendFeed来提升MySQL性能的方法

    这篇文章主要介绍了使用FriendFeed来提升MySQL性能的方法,用其来存储无模式的数据从而能够维护索引,需要的朋友可以参考下
    2015-06-06
  • 详解sql中的参照完整性(一对一,一对多,多对多)

    详解sql中的参照完整性(一对一,一对多,多对多)

    这篇文章主要介绍了sql中的参照完整性,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-04-04
  • mysql中数据库覆盖导入的几种方式总结

    mysql中数据库覆盖导入的几种方式总结

    这篇文章主要介绍了mysql中数据库覆盖导入的几种方式总结,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-03-03
  • You have an error in your SQL syntax; check the manual that corresponds解决方法

    You have an error in your SQL&

    You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version
    2023-02-02

最新评论