问题描述
我有一个在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>
但是没有提到我把它放在哪里?
总结一下:
解决方法
Cloud Run 在配置有 Cloud SQL 实例时提供 Unix 域套接字 - 它是一个可用于连接到数据库的文件。您正在使用 Cloud SQL Java 连接器,它允许您绕过 Unix 套接字(这通常在 Java 上是首选,因为 Unix 套接字不受本机支持)。
为了缩短冷启动时间,我建议您做两件事:
-
减少池中的连接数。虽然应用程序之间的最佳数量差异很大,但 20 几乎肯定会超出您的需要。根据经验,try 2 * the number of cores used as your starting value,and increase/decrease as needed。 Hikari 使用
maximumPoolSize
来做到这一点。 -
调整池中的起始连接数。 Hikari 提供
minimumIdle
,它设置池中空闲连接的最小数量,最多maximumPoolSize
。虽然 Hikari 建议不要设置此值(因此您有一个固定的池),但将其设置为 0 意味着您的池不会在启动时建立连接。这意味着您的应用程序将启动得更快,但平均需要更长的时间才能从池中获得连接。