>백엔드 개발 >Golang >Go를 사용하여 Google Cloud SQL에 연결할 때 SSL 연결 오류를 해결하는 방법은 무엇입니까?

Go를 사용하여 Google Cloud SQL에 연결할 때 SSL 연결 오류를 해결하는 방법은 무엇입니까?

DDD
DDD원래의
2024-10-24 03:37:01817검색

How to Resolve SSL Connection Error When Connecting to Google Cloud SQL with Go?

Go에서 SSL을 사용하여 Google Cloud SQL에 연결

질문:

Go 및 go-sql-driver를 사용하여 Google App Engine에서 Google Cloud SQL에 연결하면 다음 메시지와 함께 x509 인증서 오류가 발생합니다.

"x509: 인증서는 projectName이 아닌 projectName:instanceName에 유효합니다."

답변:

이 오류는 일반적으로 SSL을 사용하여 Cloud SQL에 연결할 때 추가 구성이 필요함을 나타냅니다. sql.Open() 연결 문자열에 project-id:instance-name을 지정해야 하지만, mysql 드라이버에 사용자 정의 TLSConfig를 등록할 때 ServerName 속성도 설정해야 합니다.

이 문제를 해결하려면 문제인 경우 TLS 설정에 RegisterTLSConfig 호출에 ServerName이 포함되어 있는지 확인하세요.

<code class="go">mysql.RegisterTLSConfig("custom", &tls.Config{
    RootCAs:      rootCertPool,
    Certificates: clientCert,
    ServerName:   "projectName:instanceName",
})</code>

그런 다음 연결 문자열에 ?tls=nameOfYourCustomTLSConfig를 추가하세요.

<code class="go">db, err := sql.Open("mysql", "user@cloudsql(project-id:instance-name)/dbname?tls=custom")</code>

다음 단계를 따르세요. , SSL을 사용하여 Google Cloud SQL에 대한 보안 연결을 설정할 수 있습니다.

위 내용은 Go를 사용하여 Google Cloud SQL에 연결할 때 SSL 연결 오류를 해결하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.