AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • 主页
  • 系统&网络
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • 主页
  • 系统&网络
    • 最新
    • 热门
    • 标签
  • Ubuntu
    • 最新
    • 热门
    • 标签
  • Unix
    • 最新
    • 标签
  • DBA
    • 最新
    • 标签
  • Computer
    • 最新
    • 标签
  • Coding
    • 最新
    • 标签
主页 / server / 问题 / 399487
Accepted
carpii
carpii
Asked: 2012-06-17 17:47:08 +0800 CST2012-06-17 17:47:08 +0800 CST 2012-06-17 17:47:08 +0800 CST

无法使用自签名 SSL 证书连接到 mysql

  • 772

创建自签名 SSL 证书后,我已将远程 MySQL 服务器配置为使用它们(并启用了 SSL)

我 ssh 进入我的远程服务器,并尝试使用 SSL 连接到它自己的 mysqld(MySQL 服务器是 5.5.25)..

mysql -u <user> -p --ssl=1 --ssl-cert=client.cert --ssl-key=client.key --ssl-ca=ca.cert
Enter password: 
ERROR 2026 (HY000): SSL connection error: error:00000001:lib(0):func(0):reason(1)

好的,我记得读过通过 SSL 连接到同一台服务器存在一些问题。所以我将客户端密钥下载到我的本地盒子,并从那里进行测试......

mysql -h <server> -u <user> -p --ssl=1 --ssl-cert=client.cert --ssl-key=client.key --ssl-ca=ca.cert 
Enter password: 
ERROR 2026 (HY000): SSL connection error

不清楚这个“SSL 连接错误”错误指的是什么,但是如果我省略了-ssl-ca,那么我就可以使用 SSL 进行连接。

mysql -h <server> -u <user> -p --ssl=1 --ssl-cert=client.cert --ssl-key=client.key 
Enter password: 
Welcome to the MySQL monitor.  Commands end with ; or \g.
Your MySQL connection id is 37
Server version: 5.5.25 MySQL Community Server (GPL)

但是,我相信这只是加密连接,并没有真正验证证书的有效性(这意味着我可能容易受到中间人攻击)

SSL 证书有效(尽管是自签名的),并且没有密码。所以我的问题是,我做错了什么?如何使用自签名证书通过 SSL 连接?

MySQL服务器版本为5.5.25,服务器和客户端为CentOS 5。

感谢您的任何建议

编辑:请注意,在所有情况下,命令都是从 ssl 密钥所在的同一目录发出的(因此没有绝对路径)

编辑(响应 mgorven): ca.cert是证书颁发机构证书,它应该告诉 mysql 我的证书颁发机构是可信的。

来自的配置my.cnf是

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

我也尝试添加ssl-cipher=DHE-RSA-AES256-SHA但后来删除了它,因为它没有帮助。

mysql ssl ssl-certificate mysql5.5 mysql5
  • 3 3 个回答
  • 44176 Views

3 个回答

  • Voted
  1. Best Answer
    Keith Burdis
    2012-06-18T11:37:16+08:002012-06-18T11:37:16+08:00

    是的,您是正确的,如果您不指定--ssl-ca,则客户端根本不会检查服务器证书。由于它在没有该选项的情况下工作,因此失败的最可能原因是客户端不信任服务器证书。

    如果您使用的是自签名客户端和服务器证书,则该ca.cert文件应包含这两个文件。这样,客户端将信任服务器证书,服务器将信任客户端证书。

    例如:
    生成服务器密钥和证书:

    $ openssl req -x509 -newkey rsa:1024 \
             -keyout server-key-enc.pem -out server-cert.pem \
             -subj '/DC=com/DC=example/CN=server' -passout pass:qwerty
    
    $ openssl rsa -in server-key-enc.pem -out server-key.pem \
             -passin pass:qwerty -passout pass:
    

    生成客户端密钥和证书:

    $ openssl req -x509 -newkey rsa:1024 \
             -keyout client-key-enc.pem -out client-cert.pem \
             -subj '/DC=com/DC=example/CN=client' -passout pass:qwerty
    
    $ openssl rsa -in client-key-enc.pem -out client-key.pem \
             -passin pass:qwerty -passout pass:
    

    将客户端和服务器证书合并到 CA 证书文件中:

    $ cat server-cert.pem client-cert.pem > ca.pem
    
    • 14
  2. Mircea Vutcovici
    2012-06-18T12:25:28+08:002012-06-18T12:25:28+08:00

    要使用一种方式 ssl,您应该尝试:

    mysql -u <user> -p --ssl=1 --ssl-ca=ca.cert --ssl-verify-server-cert
    

    mysql 客户端上的--ssl-cert和--ssl-key用于 2 路 SSL。这意味着基于证书的身份验证。客户端证书的主题应该是用户名。

    • 5
  3. Dmitry Leskov
    2012-06-18T07:42:59+08:002012-06-18T07:42:59+08:00

    碰巧,您没有为服务器和客户端证书输入相同的通用名称吗?如果是,请替换其中一个,以便 Common Names 不同。

    • 3

相关问题

  • 开源与专有关系 db mgt 系统的优缺点是什么?

  • 在 solaris 10 上为 mysql 设置 max_allowed_pa​​cket

  • 如何移动 MySQL 的数据目录?

  • 通过 VPN 连接什么是远程服务器 IP?

  • mysql崩溃

Sidebar

Stats

  • 问题 205573
  • 回答 270741
  • 最佳答案 135370
  • 用户 68524
  • 热门
  • 回答
  • Marko Smith

    新安装后 postgres 的默认超级用户用户名/密码是什么?

    • 5 个回答
  • Marko Smith

    SFTP 使用什么端口?

    • 6 个回答
  • Marko Smith

    命令行列出 Windows Active Directory 组中的用户?

    • 9 个回答
  • Marko Smith

    什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同?

    • 3 个回答
  • Marko Smith

    如何确定bash变量是否为空?

    • 15 个回答
  • Martin Hope
    Tom Feiner 如何按大小对 du -h 输出进行排序 2009-02-26 05:42:42 +0800 CST
  • Martin Hope
    Noah Goodrich 什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同? 2009-05-19 18:24:42 +0800 CST
  • Martin Hope
    Brent 如何确定bash变量是否为空? 2009-05-13 09:54:48 +0800 CST
  • Martin Hope
    cletus 您如何找到在 Windows 中打开文件的进程? 2009-05-01 16:47:16 +0800 CST

热门标签

linux nginx windows networking ubuntu domain-name-system amazon-web-services active-directory apache-2.4 ssh

Explore

  • 主页
  • 问题
    • 最新
    • 热门
  • 标签
  • 帮助

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve