优化从云运行服务到 GCP mysql 的连接?

问题描述

我有一个在cloud run上运行的spring boot应用,目前我只需要添加spring cloud gcp MysqL

    <dependency>
        <groupId>org.springframework.cloud</groupId>
        <artifactId>spring-cloud-gcp-starter-sql-MysqL</artifactId>
        <version>1.2.8.RELEASE</version>
    </dependency>

依赖于我的 POM,并配置我的 application.yml 文件以设置数据库名称、连接名称等,它在本地和云端运行良好。

我的 application.yml:

spring:
    cloud:
        gcp:
            sql:
                enabled: true
                database-name: pos_database
                instance-connection-name: pos-sys:asia-southeast2:pos-server-database
    datasource:
        driver-class-name: com.MysqL.cj.jdbc.Driver
        username: ***
        password: ***
        hikari:
            maximum-pool-size: 20

但是我意识到冷启动性能受到了影响,因为在启动时套接字工厂通过 SSL 套接字连接到数据库实例:

2021-05-31 13:10:07.152  INFO 1539 --- [onnection adder] c.g.cloud.sql.core.CoreSocketFactory     : 
Connecting to Cloud sql instance [pos-sys:asia-southeast2:owl-server-database] via SSL socket.

我得到一堆重复的行

2021-05-31 13:10:09.461  INFO 1539 --- [connection adder] c.g.cloud.sql.core.CoreSocketFactory     : 
Connecting to Cloud sql instance [pos-sys:asia-southeast2:pos-server-database] via SSL socket.

我知道有一种更快的连接方式,然后应用程序在云上运行,到目前为止我一直在关注本教程:

https://cloud.google.com/sql/docs/mysql/connect-run

但是我对最后一部分说我必须连接 unix socket 感到非常困惑,这是一个 docker 的东西还是在我的应用程序中? ConnectionPoolContextListener.java 在哪里 文件要走吗? 它还在文件本身的注释中说不要将它用于 java 用户,而是使用

Cloud sql JDBC 套接字工厂 但是当我转到那个链接时,它说要为 mysql-connector 添加一个依赖项,但是它不是已经包含在 spring-gcp-starter-MysqL 中了吗?它还说以这种格式创建一个连接字符串:

jdbc:MysqL:///<DATABASE_NAME>?cloudsqlInstance=<INSTANCE_CONNECTION_NAME>&socketFactory=com.google.cloud.sql.MysqL.socketFactory&user=<MysqL_USER_NAME>&password=<MysqL_USER_PASSWORD> 

但是没有提到我把它放在哪里?

总结一下:

  1. 我有一个MysqL 实例,启用了管理 api。

  2. 我通过选择我的数据库实例在我的云运行中启用连接到 Cloud sql

  3. 我对有关下一步是什么以及接下来要做什么的文档感到非常困惑。

解决方法

Cloud Run 在配置有 Cloud SQL 实例时提供 Unix 域套接字 - 它是一个可用于连接到数据库的文件。您正在使用 Cloud SQL Java 连接器,它允许您绕过 Unix 套接字(这通常在 Java 上是首选,因为 Unix 套接字不受本机支持)。

为了缩短冷启动时间,我建议您做两件事:

  1. 减少池中的连接数。虽然应用程序之间的最佳数量差异很大,但 20 几乎肯定会超出您的需要。根据经验,try 2 * the number of cores used as your starting value,and increase/decrease as needed。 Hikari 使用 maximumPoolSize 来做到这一点。

  2. 调整池中的起始连接数。 Hikari 提供 minimumIdle,它设置池中空闲连接的最小数量,最多 maximumPoolSize。虽然 Hikari 建议不要设置此值(因此您有一个固定的池),但将其设置为 0 意味着您的池不会在启动时建立连接。这意味着您的应用程序将启动得更快,但平均需要更长的时间才能从池中获得连接。