使用 Cloud SQL Go 连接器创建连接
使用集合让一切井井有条
根据您的偏好保存内容并对其进行分类。
使用 Cloud SQL Go 连接器打开与 Cloud SQL for MySQL 的连接。
深入探索
如需查看包含此代码示例的详细文档,请参阅以下内容:
代码示例
Go
如需向 Cloud SQL for MySQL 进行身份验证,请设置应用默认凭据。如需了解详情,请参阅为本地开发环境设置身份验证。
如未另行说明,那么本页面中的内容已根据知识共享署名 4.0 许可获得了许可,并且代码示例已根据 Apache 2.0 许可获得了许可。有关详情,请参阅 Google 开发者网站政策。Java 是 Oracle 和/或其关联公司的注册商标。
[[["易于理解","easyToUnderstand","thumb-up"],["解决了我的问题","solvedMyProblem","thumb-up"],["其他","otherUp","thumb-up"]],[["很难理解","hardToUnderstand","thumb-down"],["信息或示例代码不正确","incorrectInformationOrSampleCode","thumb-down"],["没有我需要的信息/示例","missingTheInformationSamplesINeed","thumb-down"],["翻译问题","translationIssue","thumb-down"],["其他","otherDown","thumb-down"]],[],[],[],null,["# Create a connection using the Cloud SQL Go Connector\n\nOpen a connection to Cloud SQL for MySQL by using the Cloud SQL Go Connector.\n\nExplore further\n---------------\n\n\nFor detailed documentation that includes this code sample, see the following:\n\n- [Connect from App Engine flexible environment](/sql/docs/mysql/connect-app-engine-flexible)\n- [Connect from App Engine standard environment](/sql/docs/mysql/connect-app-engine-standard)\n- [Connect from Cloud Run](/sql/docs/mysql/connect-run)\n- [Connect from Cloud Run functions](/sql/docs/mysql/connect-functions)\n- [Connect using Cloud SQL Language Connectors](/sql/docs/mysql/connect-connectors)\n\nCode sample\n-----------\n\n### Go\n\n\nTo authenticate to Cloud SQL for MySQL, set up Application Default Credentials.\nFor more information, see\n\n[Set up authentication for a local development environment](/docs/authentication/set-up-adc-local-dev-environment).\n\n package cloudsql\n\n import (\n \t\"context\"\n \t\"database/sql\"\n \t\"fmt\"\n \t\"log\"\n \t\"net\"\n \t\"os\"\n\n \t\"cloud.google.com/go/cloudsqlconn\"\n \t\"github.com/go-sql-driver/mysql\"\n )\n\n func connectWithConnector() (*sql.DB, error) {\n \tmustGetenv := func(k string) string {\n \t\tv := os.Getenv(k)\n \t\tif v == \"\" {\n \t\t\tlog.Fatalf(\"Fatal Error in connect_connector.go: %s environment variable not set.\", k)\n \t\t}\n \t\treturn v\n \t}\n \t// Note: Saving credentials in environment variables is convenient, but not\n \t// secure - consider a more secure solution such as\n \t// Cloud Secret Manager (https://cloud.google.com/secret-manager) to help\n \t// keep passwords and other secrets safe.\n \tvar (\n \t\tdbUser = mustGetenv(\"DB_USER\") // e.g. 'my-db-user'\n \t\tdbPwd = mustGetenv(\"DB_PASS\") // e.g. 'my-db-password'\n \t\tdbName = mustGetenv(\"DB_NAME\") // e.g. 'my-database'\n \t\tinstanceConnectionName = mustGetenv(\"INSTANCE_CONNECTION_NAME\") // e.g. 'project:region:instance'\n \t\tusePrivate = os.Getenv(\"PRIVATE_IP\")\n \t)\n\n \t// WithLazyRefresh() Option is used to perform refresh\n \t// when needed, rather than on a scheduled interval.\n \t// This is recommended for serverless environments to\n \t// avoid background refreshes from throttling CPU.\n \td, err := cloudsqlconn.https://cloud.google.com/go/docs/reference/cloud.google.com/go/cloudsqlconn/latest/index.html#cloud_google_com_go_cloudsqlconn_Dialer_NewDialer(context.Background(), cloudsqlconn.https://cloud.google.com/go/docs/reference/cloud.google.com/go/cloudsqlconn/latest/index.html#cloud_google_com_go_cloudsqlconn_Option_WithLazyRefresh())\n \tif err != nil {\n \t\treturn nil, fmt.Errorf(\"cloudsqlconn.NewDialer: %w\", err)\n \t}\n \tvar opts []cloudsqlconn.https://cloud.google.com/go/docs/reference/cloud.google.com/go/cloudsqlconn/latest/index.html#cloud_google_com_go_cloudsqlconn_DialOption\n \tif usePrivate != \"\" {\n \t\topts = append(opts, cloudsqlconn.https://cloud.google.com/go/docs/reference/cloud.google.com/go/cloudsqlconn/latest/index.html#cloud_google_com_go_cloudsqlconn_DialOption_WithPrivateIP())\n \t}\n \tmysql.RegisterDialContext(\"cloudsqlconn\",\n \t\tfunc(ctx context.Context, addr string) (net.Conn, error) {\n \t\t\treturn d.https://cloud.google.com/go/docs/reference/cloud.google.com/go/cloudsqlconn/latest/index.html#cloud_google_com_go_cloudsqlconn_Dialer_Dial(ctx, instanceConnectionName, opts...)\n \t\t})\n\n \tdbURI := fmt.Sprintf(\"%s:%s@cloudsqlconn(localhost:3306)/%s?parseTime=true\",\n \t\tdbUser, dbPwd, dbName)\n\n \tdbPool, err := sql.Open(\"mysql\", dbURI)\n \tif err != nil {\n \t\treturn nil, fmt.Errorf(\"sql.Open: %w\", err)\n \t}\n \treturn dbPool, nil\n }\n\nWhat's next\n-----------\n\n\nTo search and filter code samples for other Google Cloud products, see the\n[Google Cloud sample browser](/docs/samples?product=cloud_sql_mysql)."]]