前提
GoogleCloudのGCE上にて、SpringBootでWebAPIを開発しています。
Springプロジェクトは正常に起動することを確認済です。
Java 11
Spring 2.7.6
mysql 5.7
実現したいこと
SpringBootからCloudSQLへ接続し、DBからデータを取得したい。
発生している問題
下記エラーが発生して、接続ができない。
java.sql.SQLException: Access denied for user 'root'@'cloudsqlproxy~192.168.0.5' (using password: YES)
試したこと
1.ローカル環境での接続
ローカル環境にMySQLをインストールし、接続。DBからのデータを呼び出せた。OK
2.GCEにデプロイ後、Postmanでリクエストし、レスポンス確認(DB使わない)→レスポンスをPostmanで受け取れた。OK
3.GCEにSSH接続し、mysqlコマンドを使ってMySQLへ接続→接続することができテーブル内容も確認することができた。OK
4.DBを使ったレスポンス→接続がうまく行かずNG
設定ファイル
build.gradle
Java plugins { id 'java' id 'org.springframework.boot' version '2.7.6' id 'io.spring.dependency-management' version '1.0.15.RELEASE' } group = 'com.example' version = '0.0.1-SNAPSHOT' sourceCompatibility = '11' configurations { compileOnly { extendsFrom annotationProcessor } } repositories { mavenCentral() } dependencies { // implementation 'org.springframework.boot:spring-boot-starter-security' // implementation 'org.springframework.boot:spring-boot-starter-thymeleaf' implementation 'org.springframework.boot:spring-boot-starter-web' // implementation 'org.thymeleaf.extras:thymeleaf-extras-springsecurity5' compileOnly 'org.projectlombok:lombok' developmentOnly 'org.springframework.boot:spring-boot-devtools' annotationProcessor 'org.projectlombok:lombok' testImplementation 'org.springframework.boot:spring-boot-starter-test' // testImplementation 'org.springframework.security:spring-security-test' implementation 'org.mybatis.spring.boot:mybatis-spring-boot-starter:2.3.0' runtimeOnly 'mysql:mysql-connector-java' runtimeOnly 'com.google.cloud.sql:mysql-socket-factory-connector-j-8:1.0.15' } tasks.named('test') { useJUnitPlatform() }
application.properties
database=mysql spring.datasource.driverClassName=com.mysql.jdbc.Driver spring.datasource.url=jdbc:mysql://google/<DB-Name>?cloudSqlInstance=<CONNECTION NAME>&socketFactory=com.google.cloud.sql.mysql.SocketFactory spring.datasource.username=root spring.datasource.password=<PASSWORD>
エラーログ
2022-12-21 13:49:25.022 ERROR 1576 --- [nio-8080-exec-1] o.a.c.c.C.[.[.[/].[dispatcherServlet] : Servlet.service() for servlet [dispatcherServlet] in context with path [] threw exception [Request processing failed; nested exception is org.mybatis.spring.MyBatisSystemException: nested exception is org.apache.ibatis.exceptions.PersistenceException: ### Error querying database. Cause: org.springframework.jdbc.CannotGetJdbcConnectionException: Failed to obtain JDBC Connection; nested exception is java.sql.SQLException: Access denied for user 'root'@'cloudsqlproxy~192.168.0.5' (using password: YES)

回答1件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。