首页  >  文章  >  后端开发  >  如何使用 Go 从 App Engine 连接到带有 SSL 的 Cloud SQL 并解决证书错误?

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

Linda Hamilton
Linda Hamilton原创
2024-10-23 17:48:21324浏览

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中文网其他相关文章!

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn