JHipster 6.0.1 的 Docker Compose 部署:Java 堆空间

4
我有两个应用程序。App 1 使用 JHipster 5.8.2,我将其部署到 Digital Ocean 的 droplet 上,该 droplet 有 2GB RAM,在将镜像推到 gitlab 的 registry 后,我运行 docker-compose -f app.yml up(其中包含_JAVA_OPTIONS=-Xmx512m -Xms256m),大约 45 秒内一切都运行得很完美。
App 2 使用 JHipster 6.0.1 生成(实际上是我的 App 1 的升级版)。我为我的 App 2 使用了与 App 1 相似的 droplet:单核 2GB RAM,但是因为Java Heap Space而失败了。在此之后,我将我的 droplet 更改为 4GB 2 核心 droplet,并将我的 app.yml 配置更改为: _JAVA_OPTIONS=-Xmx3072m -Xms2048m 但仍然出现相同的问题,并且需要 40 分钟。
在出现此错误之后,我尝试在我的计算机上使用 32GB 运行镜像,但在 2 1/2 小时后,出现了相同的问题。
以下是我如何打包我的 6.0.1 应用程序:
  • /mvnw verify -Pprod -DskipTests
  • ./mvnw jib:build -Dimage=registry.gitlab.com/amatos/project
在我的 droplet 中:
  • docker-compose -f app.yml up -d
这应该可以工作,但它永远无法通过 Web application fully configured 这一行,并且在几分钟后(取决于 RAM 的数量)失败。
我是否漏掉了其他步骤?

发现:

经过大量测试后,我发现添加自定义 DTO 会导致 Java 堆空间问题。

生成的 DTO:

package com.facturapp.service.dto;
import javax.validation.constraints.*;
import java.io.Serializable;
import java.util.Objects;
import javax.persistence.Lob;

/**
 * A DTO for the {@link com.facturapp.domain.Address} entity.
 */
public class AddressDTO implements Serializable {

    private Long id;

    @NotNull
    private String name;

    private String contact;

    private String mobile;

    private String address;

    @Lob
    private String note;

    private Boolean delivery;

    private Boolean invoicing;

    private Boolean active;


    private Long districtId;

    private String districtName;

    private Long partnerId;

    private String partnerName;

    public Long getId() {
        return id;
    }

    public void setId(Long id) {
        this.id = id;
    }

    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }

    public String getContact() {
        return contact;
    }

    public void setContact(String contact) {
        this.contact = contact;
    }

    public String getMobile() {
        return mobile;
    }

    public void setMobile(String mobile) {
        this.mobile = mobile;
    }

    public String getAddress() {
        return address;
    }

    public void setAddress(String address) {
        this.address = address;
    }

    public String getNote() {
        return note;
    }

    public void setNote(String note) {
        this.note = note;
    }

    public Boolean isDelivery() {
        return delivery;
    }

    public void setDelivery(Boolean delivery) {
        this.delivery = delivery;
    }

    public Boolean isInvoicing() {
        return invoicing;
    }

    public void setInvoicing(Boolean invoicing) {
        this.invoicing = invoicing;
    }

    public Boolean isActive() {
        return active;
    }

    public void setActive(Boolean active) {
        this.active = active;
    }

    public Long getDistrictId() {
        return districtId;
    }

    public void setDistrictId(Long districtId) {
        this.districtId = districtId;
    }

    public String getDistrictName() {
        return districtName;
    }

    public void setDistrictName(String districtName) {
        this.districtName = districtName;
    }

    public Long getPartnerId() {
        return partnerId;
    }

    public void setPartnerId(Long partnerId) {
        this.partnerId = partnerId;
    }

    public String getPartnerName() {
        return partnerName;
    }

    public void setPartnerName(String partnerName) {
        this.partnerName = partnerName;
    }

    @Override
    public boolean equals(Object o) {
        if (this == o) {
            return true;
        }
        if (o == null || getClass() != o.getClass()) {
            return false;
        }

        AddressDTO addressDTO = (AddressDTO) o;
        if (addressDTO.getId() == null || getId() == null) {
            return false;
        }
        return Objects.equals(getId(), addressDTO.getId());
    }

    @Override
    public int hashCode() {
        return Objects.hashCode(getId());
    }

    @Override
    public String toString() {
        return "AddressDTO{" +
            "id=" + getId() +
            ", name='" + getName() + "'" +
            ", contact='" + getContact() + "'" +
            ", mobile='" + getMobile() + "'" +
            ", address='" + getAddress() + "'" +
            ", note='" + getNote() + "'" +
            ", delivery='" + isDelivery() + "'" +
            ", invoicing='" + isInvoicing() + "'" +
            ", active='" + isActive() + "'" +
            ", district=" + getDistrictId() +
            ", district='" + getDistrictName() + "'" +
            ", partner=" + getPartnerId() +
            ", partner='" + getPartnerName() + "'" +
            "}";
    }
}

自定义数据传输对象

package com.facturapp.service.dto;

import com.facturapp.domain.District;

/**
 * A DTO for the {@link com.facturapp.domain.Address} entity.
 */
public class AddressFaDTO extends AddressDTO {

    private District district;

    public District getDistrict() {
        return district;
    }

    public void setDistrict(District district) {
        this.district = district;
    }
}


自定义的 DTO 是 Address,继承自生成的 DTO。生成的 DTO 有一些字段,其中 2 个是 districtId (Long)districtName (String),但是我的自定义 DTO 还有一个 district (District)。类 District 有一个属性 Province,它也有 Region,它也有 Country。因此,当我检索一个 Address 时,我也会得到区、省、地区和国家。
我的自定义资源调用了一个自定义服务,该服务检索带有区域和所有其他类的自定义 DTO。
如果我使用生成的 DTO,我没有问题,但是当我使用我的自定义 DTO 时,应用程序无法运行,并因 Java 堆空间而失败。
错误日志:
facturapp_1  | 2019-06-03 06:56:20.395  INFO 1 --- [  restartedMain] com.almasoft.facturapp.FacturApp         : Starting FacturApp on c40efbe18b21 with PID 1 (/app/classes started by root in /)
facturapp_1  | 2019-06-03 06:56:20.407  INFO 1 --- [  restartedMain] com.almasoft.facturapp.FacturApp         : The following profiles are active: prod,swagger
facturapp_1  | 2019-06-03 06:56:45.918  WARN 1 --- [  restartedMain] i.g.j.c.liquibase.AsyncSpringLiquibase   : Warning, Liquibase took more than 5 seconds to start up!
facturapp_1  | 2019-06-03 06:56:57.351  INFO 1 --- [  restartedMain] c.a.facturapp.config.WebConfigurer       : Web application configuration, using profiles: prod
facturapp_1  | 2019-06-03 06:56:57.353  INFO 1 --- [  restartedMain] c.a.facturapp.config.WebConfigurer       : Web application fully configured
facturapp_1  | WARNING: An illegal reflective access operation has occurred
facturapp_1  | WARNING: Illegal reflective access by org.springframework.cglib.core.ReflectUtils (file:/app/libs/spring-core-5.1.6.RELEASE.jar) to method java.lang.ClassLoader.defineClass(java.lang.String,byte[],int,int,java.security.ProtectionDomain)
facturapp_1  | WARNING: Please consider reporting this to the maintainers of org.springframework.cglib.core.ReflectUtils
facturapp_1  | WARNING: Use --illegal-access=warn to enable warnings of further illegal reflective access operations
facturapp_1  | WARNING: All illegal access operations will be denied in a future release
facturapp_1  | 2019-06-03 07:03:27.207  WARN 1 --- [  restartedMain] ConfigServletWebServerApplicationContext : Exception encountered during context initialization - cancelling refresh attempt: org.springframework.context.ApplicationContextException: Failed to start bean 'documentationPluginsBootstrapper'; nested exception is com.google.common.util.concurrent.ExecutionError: java.lang.OutOfMemoryError: Java heap space
facturapp_1  | 2019-06-03 07:03:27.606 ERROR 1 --- [  restartedMain] o.s.boot.SpringApplication               : Application run failed
facturapp_1  |
facturapp_1  | org.springframework.context.ApplicationContextException: Failed to start bean 'documentationPluginsBootstrapper'; nested exception is com.google.common.util.concurrent.ExecutionError: java.lang.OutOfMemoryError: Java heap space
facturapp_1  |  at org.springframework.context.support.DefaultLifecycleProcessor.doStart(DefaultLifecycleProcessor.java:185)
facturapp_1  |  at org.springframework.context.support.DefaultLifecycleProcessor.access$200(DefaultLifecycleProcessor.java:53)
facturapp_1  |  at org.springframework.context.support.DefaultLifecycleProcessor$LifecycleGroup.start(DefaultLifecycleProcessor.java:360)
facturapp_1  |  at org.springframework.context.support.DefaultLifecycleProcessor.startBeans(DefaultLifecycleProcessor.java:158)
facturapp_1  |  at org.springframework.context.support.DefaultLifecycleProcessor.onRefresh(DefaultLifecycleProcessor.java:122)
facturapp_1  |  at org.springframework.context.support.AbstractApplicationContext.finishRefresh(AbstractApplicationContext.java:893)
facturapp_1  |  at org.springframework.boot.web.servlet.context.ServletWebServerApplicationContext.finishRefresh(ServletWebServerApplicationContext.java:163)
facturapp_1  |  at org.springframework.context.support.AbstractApplicationContext.refresh(AbstractApplicationContext.java:552)
facturapp_1  |  at org.springframework.boot.web.servlet.context.ServletWebServerApplicationContext.refresh(ServletWebServerApplicationContext.java:142)
facturapp_1  |  at org.springframework.boot.SpringApplication.refresh(SpringApplication.java:775)
facturapp_1  |  at org.springframework.boot.SpringApplication.refreshContext(SpringApplication.java:397)
facturapp_1  |  at org.springframework.boot.SpringApplication.run(SpringApplication.java:316)
facturapp_1  |  at com.facturapp.FacturApp.main(FacturApp.java:63)
facturapp_1  |  at java.base/jdk.internal.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
facturapp_1  |  at java.base/jdk.internal.reflect.NativeMethodAccessorImpl.invoke(Unknown Source)
facturapp_1  |  at java.base/jdk.internal.reflect.DelegatingMethodAccessorImpl.invoke(Unknown Source)
facturapp_1  |  at java.base/java.lang.reflect.Method.invoke(Unknown Source)
facturapp_1  |  at org.springframework.boot.devtools.restart.RestartLauncher.run(RestartLauncher.java:49)
facturapp_1  | Caused by: com.google.common.util.concurrent.ExecutionError: java.lang.OutOfMemoryError: Java heap space
facturapp_1  |  at com.google.common.cache.LocalCache$Segment.get(LocalCache.java:2049)
facturapp_1  |  at com.google.common.cache.LocalCache.get(LocalCache.java:3953)
facturapp_1  |  at com.google.common.cache.LocalCache.getOrLoad(LocalCache.java:3976)
facturapp_1  |  at com.google.common.cache.LocalCache$LocalLoadingCache.get(LocalCache.java:4960)
facturapp_1  |  at springfox.documentation.schema.CachingModelDependencyProvider.dependentModels(CachingModelDependencyProvider.java:58)
facturapp_1  |  at springfox.documentation.schema.DefaultModelProvider.dependencies(DefaultModelProvider.java:128)
facturapp_1  |  at springfox.documentation.schema.CachingModelProvider.dependencies(CachingModelProvider.java:68)
facturapp_1  |  at springfox.documentation.spring.web.scanners.ApiModelReader.populateDependencies(ApiModelReader.java:136)
facturapp_1  |  at springfox.documentation.spring.web.scanners.ApiModelReader.read(ApiModelReader.java:78)
facturapp_1  |  at springfox.documentation.spring.web.scanners.ApiListingScanner.scan(ApiListingScanner.java:133)
facturapp_1  |  at springfox.documentation.spring.web.scanners.ApiDocumentationScanner.scan(ApiDocumentationScanner.java:71)
facturapp_1  |  at springfox.documentation.spring.web.plugins.DocumentationPluginsBootstrapper.scanDocumentation(DocumentationPluginsBootstrapper.java:101)
facturapp_1  |  at springfox.documentation.spring.web.plugins.DocumentationPluginsBootstrapper.start(DocumentationPluginsBootstrapper.java:167)
facturapp_1  |  at org.springframework.context.support.DefaultLifecycleProcessor.doStart(DefaultLifecycleProcessor.java:182)
facturapp_1  |  ... 17 common frames omitted
facturapp_1  | Caused by: java.lang.OutOfMemoryError: Java heap space
facturapp_1  |  at java.base/java.util.Arrays.copyOf(Unknown Source)
facturapp_1  |  at java.base/java.util.ArrayList.grow(Unknown Source)
facturapp_1  |  at java.base/java.util.ArrayList.addAll(Unknown Source)
facturapp_1  |  at springfox.documentation.schema.DefaultModelDependencyProvider.resolvedPropertiesAndFields(DefaultModelDependencyProvider.java:181)
facturapp_1  |  at springfox.documentation.schema.DefaultModelDependencyProvider.resolvedDependencies(DefaultModelDependencyProvider.java:120)
facturapp_1  |  at springfox.documentation.schema.DefaultModelDependencyProvider.maybeFromRegularType(DefaultModelDependencyProvider.java:207)
facturapp_1  |  at springfox.documentation.schema.DefaultModelDependencyProvider.resolvedPropertiesAndFields(DefaultModelDependencyProvider.java:183)
facturapp_1  |  at springfox.documentation.schema.DefaultModelDependencyProvider.resolvedDependencies(DefaultModelDependencyProvider.java:120)
facturapp_1  |  at springfox.documentation.schema.DefaultModelDependencyProvider.maybeFromRegularType(DefaultModelDependencyProvider.java:207)
facturapp_1  |  at springfox.documentation.schema.DefaultModelDependencyProvider.resolvedPropertiesAndFields(DefaultModelDependencyProvider.java:183)
facturapp_1  |  at springfox.documentation.schema.DefaultModelDependencyProvider.resolvedDependencies(DefaultModelDependencyProvider.java:120)
facturapp_1  |  at springfox.documentation.schema.DefaultModelDependencyProvider.maybeFromCollectionElementType(DefaultModelDependencyProvider.java:220)
facturapp_1  |  at springfox.documentation.schema.DefaultModelDependencyProvider.resolvedPropertiesAndFields(DefaultModelDependencyProvider.java:181)
facturapp_1  |  at springfox.documentation.schema.DefaultModelDependencyProvider.resolvedDependencies(DefaultModelDependencyProvider.java:120)
facturapp_1  |  at springfox.documentation.schema.DefaultModelDependencyProvider.maybeFromCollectionElementType(DefaultModelDependencyProvider.java:220)
facturapp_1  |  at springfox.documentation.schema.DefaultModelDependencyProvider.resolvedPropertiesAndFields(DefaultModelDependencyProvider.java:181)
facturapp_1  |  at springfox.documentation.schema.DefaultModelDependencyProvider.resolvedDependencies(DefaultModelDependencyProvider.java:120)
facturapp_1  |  at springfox.documentation.schema.DefaultModelDependencyProvider.maybeFromCollectionElementType(DefaultModelDependencyProvider.java:220)
facturapp_1  |  at springfox.documentation.schema.DefaultModelDependencyProvider.resolvedPropertiesAndFields(DefaultModelDependencyProvider.java:181)
facturapp_1  |  at springfox.documentation.schema.DefaultModelDependencyProvider.resolvedDependencies(DefaultModelDependencyProvider.java:120)
facturapp_1  |  at springfox.documentation.schema.DefaultModelDependencyProvider.maybeFromRegularType(DefaultModelDependencyProvider.java:207)
facturapp_1  |  at springfox.documentation.schema.DefaultModelDependencyProvider.resolvedPropertiesAndFields(DefaultModelDependencyProvider.java:183)
facturapp_1  |  at springfox.documentation.schema.DefaultModelDependencyProvider.resolvedDependencies(DefaultModelDependencyProvider.java:120)
facturapp_1  |  at springfox.documentation.schema.DefaultModelDependencyProvider.dependentModels(DefaultModelDependencyProvider.java:79)
facturapp_1  |  at springfox.documentation.schema.CachingModelDependencyProvider$1.load(CachingModelDependencyProvider.java:50)
facturapp_1  |  at springfox.documentation.schema.CachingModelDependencyProvider$1.load(CachingModelDependencyProvider.java:48)
facturapp_1  |  at com.google.common.cache.LocalCache$LoadingValueReference.loadFuture(LocalCache.java:3529)
facturapp_1  |  at com.google.common.cache.LocalCache$Segment.loadSync(LocalCache.java:2278)
facturapp_1  |  at com.google.common.cache.LocalCache$Segment.lockedGetOrLoad(LocalCache.java:2155)
facturapp_1  |  at com.google.common.cache.LocalCache$Segment.get(LocalCache.java:2045)
facturapp_1  |  at com.google.common.cache.LocalCache.get(LocalCache.java:3953)
facturapp_1  |  at com.google.common.cache.LocalCache.getOrLoad(LocalCache.java:3976)

我的问题是:

  1. 为什么我只是扩展一个简单的DTO就会遇到这样的问题?
  2. 我该如何解决这个问题?

我无法从默认应用程序中重现此问题,可能与您在生成应用程序和实体时的选择有关。不确定这是否重要,但文档建议使用 ./mvnw package -Pprod verify jib:build,这与您的命令略有不同。https://www.jhipster.tech/docker-compose/#3 - Jon Ruddell
我已经添加了我的 yo_rc.json 文件。我按照建议运行了命令,但结果仍然相同。顺便说一下:我有50个实体,不知道这是否重要。 - Alejandro
1个回答

0
我的错误是将领域类用作地址的字段,而不是DTO类。
问题仍然在于启动应用程序时存在内存问题,而非调用使用有问题的类的方法时。

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接