RuntimeException для облачного SQL API и создание bean-компонентов для развернутого Java-приложения в Google App Engine - PullRequest
0 голосов
/ 03 июля 2019

Я получаю следующие два исключения в отчете об ошибках моего развернутого приложения:

(1) RuntimeException: невозможно получить учетные данные для связи с Cloud SQL API

(2) RuntimeException: org.springframework.beans.factory.BeanCreationException: Ошибка создания бина с именем applicationController

Проект отлично работает в localhost, а также mvn appengine: run отлично работает.

Мой pom.xml :

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>
    <parent>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-parent</artifactId>
        <version>2.1.1.RELEASE</version>
        <relativePath /> <!-- lookup parent from repository -->
    </parent>
    <groupId>com.sample</groupId>
    <artifactId>catapi</artifactId>
    <version>0.0.1-SNAPSHOT</version>
    <name>catapi</name>
    <packaging>war</packaging>
    <description>Demo project for Spring Boot</description>

    <properties>
        <projectID>swathitest1</projectID> 
        <sql.dbName>swathi-db</sql.dbName>
        <sql.instanceName>${projectID}:asia-south1:${sql.dbName}</sql.instanceName>
        <sql.userName>postgres</sql.userName>
        <sql.password>Welcome1!</sql.password>
        <database>test</database> 
        <sqlURL>jdbc:postgresql://google/${database}?useSSL=false&amp;socketFactoryArg=${sql.instanceName}&amp;socketFactory=com.google.cloud.sql.postgres.SocketFactory&amp;user=${sql.userName}&amp;password=${sql.password}</sqlURL>
        <appengine.maven.plugin>1.3.2</appengine.maven.plugin>

        <java.version>1.8</java.version>
    </properties>

    <dependencyManagement>
        <dependencies>
          <dependency>
          <groupId>org.springframework.cloud</groupId>
          <artifactId>spring-cloud-gcp-dependencies</artifactId>
          <version>1.0.0.RC1</version>
          <type>pom</type>
          <scope>import</scope>
          </dependency>
       </dependencies>
    </dependencyManagement>

<dependencies>
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter</artifactId>
    </dependency>
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-web</artifactId>
    </dependency>
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-jdbc</artifactId>
    </dependency>

    <!--dependency>
        <groupId>org.springframework.cloud</groupId>
        <artifactId>spring-cloud-gcp-starter-sql</artifactId>
        <version>1.0.0.BUILD-SNAPSHOT</version>
    </dependency-->

    <dependency>
        <groupId>org.postgresql</groupId>
        <artifactId>postgresql</artifactId>
        <scope>runtime</scope>
        <version>42.1.1</version>
    </dependency>

    <dependency>
      <groupId>javax.servlet</groupId>
      <artifactId>javax.servlet-api</artifactId>
      <version>3.1.0</version>
      <scope>provided</scope>
    </dependency>
    <dependency>
      <groupId>org.slf4j</groupId>
      <artifactId>jul-to-slf4j</artifactId>
      <scope>provided</scope>
    </dependency>

    <dependency>
        <groupId>com.google.cloud.sql</groupId>
        <artifactId>postgres-socket-factory</artifactId>
        <version>1.0.4</version>
    </dependency>

    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-test</artifactId>
        <scope>test</scope>
    </dependency>
</dependencies>

<repositories>
  <!-- Use Spring Milestone Repository -->
  <repository>
    <id>repository.spring.milestone</id>
    <name>Spring Milestones Repository</name>
    <url>http://repo.spring.io/milestone</url>
  </repository>
</repositories>

<build>
    <plugins>
        <plugin>
          <groupId>com.google.cloud.tools</groupId>
          <artifactId>appengine-maven-plugin</artifactId>
          <version>1.3.2</version>
          <configuration>
            <version>1</version>
          </configuration>
        </plugin>
        <plugin>
          <groupId>org.springframework.boot</groupId>
          <artifactId>spring-boot-maven-plugin</artifactId>
        </plugin>
    </plugins>
</build>

</project>

Мои application.properties Файл:

spring.jpa.properties.hibernate.dialect = org.hibernate.dialect.PostgreSQLDialect
spring.jpa.hibernate.ddl-auto=create
spring.jpa.hibernate.show-sql=true

spring.datasource.url=jdbc:postgresql://google/test?socketFactory=com.google.cloud.sql.postgres.SocketFactory&socketFactoryArg=swathitest1:asia-south1:swathi-db
#spring.datasource.url=jdbc:postgresql://35.200.222.222:5432/test
spring.datasource.username=postgres
spring.datasource.password=Welcome1!

spring.datasource.initialization-mode=always
spring.datasource.initialize=true
spring.datasource.schema=classpath:/schema.sql
spring.datasource.continue-on-error=true

My appengine-web.xml :

<?xml version="1.0" encoding="utf-8"?>
<appengine-web-app xmlns="http://appengine.google.com/ns/1.0">
  <application>swathitest1</application>
  <version>1</version>
  <threadsafe>true</threadsafe>
  <runtime>java8</runtime>
  <!-- Configure java.util.logging -->
  <system-properties>
    <property name="java.util.logging.config.file" value="WEB-INF/logging.properties"/>
  </system-properties>

  <static-files>
    <include path="/static/**" />
  </static-files>

  <resource-files>
    <include path="/resources/**" />
  </resource-files>

  <sessions-enabled>true</sessions-enabled>
  <async-session-persistence enabled="true" />
</appengine-web-app>

Полная трассировка стека журналов ошибок:

BeanCreationException

cloudSQLerror1 cloudSQLerror2 cloudSQLerror3

Может кто-нибудь помочь мне с отладкой этой проблемы?

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...