首页 > 后端开发 > Golang > 正文

如何使用 Go 从 App Engine 连接到带有 SSL 的 Cloud SQL 并解决证书错误?

Linda Hamilton
发布: 2024-10-23 17:48:21
原创
323 人浏览过

How to Connect to Cloud SQL with SSL using Go from App Engine and Resolve Certificate Errors?

使用 Go 从 App Engine 连接到 Cloud SQL

Google 的文档建议使用以下代码使用 Go 连接到 Cloud SQL, go-sql-driver:

import "database/sql"
import _ "github.com/go-sql-driver/mysql"

db, err := sql.Open("mysql", "user@cloudsql(project-id:instance-name)/dbname")
登录后复制

但是,这可能会导致 x509 证书错误,指示指定项目名称和实例名称的证书无效。使用 SSL 连接时会出现此问题。要解决此问题,除了在 sql.Open() 中指定 project-id:instance-name 之外,还必须在向 mysql 驱动程序注册自定义 TLSConfig 时设置 ServerName 属性。

下面是一个示例设置 TLS 配置:

mysql.RegisterTLSConfig("custom", &tls.Config{
    RootCAs:      rootCertPool,
    Certificates: clientCert,
    ServerName:   "projectName:instanceName",
})
登录后复制

接下来,将 ?tls=nameOfYourCustomTLSConfig 附加到连接字符串:

db, err := sql.Open("mysql", "user@cloudsql(project-id:instance-name)/dbname?tls=custom")
登录后复制

通过执行以下步骤,您可以使用以下命令成功连接到 Cloud SQL:来自 Google App Engine 的 SSL。

以上是如何使用 Go 从 App Engine 连接到带有 SSL 的 Cloud SQL 并解决证书错误?的详细内容。更多信息请关注PHP中文网其他相关文章!

来源:php
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
作者最新文章
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责声明 Sitemap
PHP中文网:公益在线PHP培训,帮助PHP学习者快速成长!