使用maven

时间:2017-12-15 10:34:34

标签: angular maven google-app-engine spring-boot google-cloud-platform

我尝试在GoogleCloud上部署应用程序(目前是免费帐户)。 FrontEnd(Angular)和BackEnd(Java / JPA / SpringBoot)使用maven在单个.jar中构建。

本地,在我的服务器上使用Jenkins和Google Shell:

  

mvn spring-boot:run => 正常工作

但是当我尝试部署

  

mvn appengine:deploy => 502错误

部署标志为成功。但是当我检查日志时(gcloud app logs tail -s default)SpringBoot部署似乎冻结,重启,再次冻结...... 是什么让我发疯...有时它正在工作......在SpringBoot再次重启之前几分钟。

所以,我需要一些建议才能找到错误。

这是我的pom.xml

https://maven.apache.org/xsd/maven-4.0.0.xsd”     xmlns:xsi =“http://www.w3.org/2001/XMLSchema-instance”xmlns =“http://maven.apache.org/POM/4.0.0”>

<modelVersion>4.0.0</modelVersion>

<artifactId>back-office</artifactId>
<name>back-office</name>
<description>Back Office</description>

<parent>
    <groupId>fr.test</groupId>
    <artifactId>mon-parent</artifactId>
    <version>0.0.1-SNAPSHOT</version>
</parent>

<dependencies>
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-mail</artifactId>
    </dependency>
    <dependency>
        <groupId>org.thymeleaf</groupId>
        <artifactId>thymeleaf-spring4</artifactId>
    </dependency>
    <dependency>
        <groupId>nz.net.ultraq.thymeleaf</groupId>
        <artifactId>thymeleaf-layout-dialect</artifactId>
    </dependency>
    <dependency>
        <groupId>net.sf.jasperreports</groupId>
        <artifactId>jasperreports</artifactId>
        <version>6.1.0</version>
    </dependency>
    <!-- BOOT -->
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-web</artifactId>
    </dependency>
    <!-- PERSISTENCE -->
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-data-jpa</artifactId>
    </dependency>
    <dependency>
        <groupId>mysql</groupId>
        <artifactId>mysql-connector-java</artifactId>
    </dependency>
    <!-- SECURITY -->
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-security</artifactId>
    </dependency>
    <dependency>
        <groupId>com.nimbusds</groupId>
        <artifactId>nimbus-jose-jwt</artifactId>
        <version>4.39.2</version>
    </dependency>
    <dependency>
        <groupId>joda-time</groupId>
        <artifactId>joda-time</artifactId>
    </dependency>
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-test</artifactId>
        <scope>test</scope>
    </dependency>
    <dependency>
        <groupId>fr.test</groupId>
        <artifactId>front-office</artifactId>
        <version>${project.version}</version>
        <scope>runtime</scope>
    </dependency>
</dependencies>

<repositories>
  ....
</repositories>

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

这是我的app.yaml配置(在src / main / appengine中)

# [START runtime]
runtime: java
env: flex

handlers:
- url: /.*
  script: this field is required, but ignored

runtime_config:  # Optional
  jdk: openjdk8
 # server: jetty9

manual_scaling:
  instances: 1
# [END runtime]

1 个答案:

答案 0 :(得分:1)

根据您描述的症状,我怀疑您的应用程序容器内存不足并被OOM杀手杀死。

默认的Flex VM只有1GB的内存,而且只有600MB留给应用程序容器。

告诉内存存在问题的一个可靠方法是在Google Cloud Logging UI的vm.syslog中找到类似内容。

kernel: [  133.706951] Out of memory: Kill process 4490 (java) score 878 or sacrifice child 
kernel: [  133.714468] Killed process 4306 (java) total-vm:5332376kB, anon-rss:2712108kB, file-rss:0k

尝试通过将此内容添加到app.yaml

来增加内存
resources:
  memory_gb: 4