首页 > 解决方案 > Heroku:使用 `gitlab-ci` 部署 jhipster 项目由于`Procfile`命令而崩溃

问题描述

我之前在jhipster-generatorGithub 问题上问过这个问题。但仍然没有得到解决方案。

(在我的 Gitlab和Github 问题#9426上的示例存储库中查看更多信息)

我认为它与Procfile我从生成器中获得的最终命令有关,这些命令定义如下:

web: java $JAVA_OPTS -Xmx256m -jar target/*.war --spring.profiles.active=prod,heroku,no-liquibase --server.port=$PORT 
release: cp -R src/main/resources/config config && ./mvnw liquibase:update -Pheroku
  1. 命令上release:的命令cp -R ...无法执行,因为从 gitlab-ci 的最后一项工作中可以正常工作并获得绿色响应。但是当我看到登录 Heroku 部署实例时,我得到了src/main/resource/config not found. 然后我尝试通过添加进行更多调查ls * -ltrrelease:发现甚至找不到src目录。只有target目录在那里。

  2. 所以我再次尝试release:从尝试中删除该行Procfile,然后我从运行应用程序的 Heroku 服务器收到崩溃消息。

    • 日志的一部分
2019-03-26T03:18:10.547189+00:00 app[web.1]: 03:18:10.536 [localhost-startStop-1] ERROR org.springframework.boot.SpringApplication - Application run failed
2019-03-26T03:18:10.547217+00:00 app[web.1]: java.util.ServiceConfigurationError: javax.cache.spi.CachingProvider: Provider org.redisson.jcache.JCachingProvider not a subtype
...
2019-03-26T03:18:10.567009+00:00 app[web.1]: java.util.concurrent.ExecutionException: org.apache.catalina.LifecycleException: Failed to start component [StandardEngine[Tomcat].StandardHost[localhost].StandardContext[]]

但是,如果我使用命令运行,jhipster heroku它将使用与.gitlab-ci.yml文件中定义的命令不同的方法进行部署。并且可以成功运行。

因此,由于Heroku 部署文档,我认为它与我现在发现的问题最相关,我应该修复什么Procfile才能让 Heroku 上的最终部署可以正常工作?

任何帮助将不胜感激,并提前感谢您。

标签: mavenspring-bootherokujhipstergitlab-ci

解决方案


TLDR ;

我做了这些事情,然后带有Gitlab->的HerokuCI-CD 可以正确执行 CI-CD。

at Procfile,删除该release:行,因为执行状态.gitlab-ci.yml时文件所做deploy-to-production的是部署JAR文件,而不包括整个项目目录,因此,从项目目录复制文件不再重要。

现在你可以运行 CI-CD 并且在Gitlab管道上和Deployed succeed上都是绿色的Heroku

但是有一些问题会阻止您的应用程序正常运行。在这里我发现了什么。

# ===================================================================
# Spring Boot configuration for the "heroku" profile.
#
# This configuration overrides the application.yml file.
# ===================================================================

# ===================================================================
# Standard Spring Boot properties.
# Full reference is available at:
# http://docs.spring.io/spring-boot/docs/current/reference/html/common-application-properties.html
# ===================================================================

eureka:
    instance:
        hostname: jhip-cicd-bug.herokuapp.com
        non-secure-port: 80
        prefer-ip-address: false

spring:
    datasource:
        type: com.zaxxer.hikari.HikariDataSource
        url: ${JDBC_DATABASE_URL}
        username: ${JDBC_DATABASE_USERNAME}
        password: ${JDBC_DATABASE_PASSWORD}
        hikari:
            maximumPoolSize: 8
    data:
        jest:
            uri: ${BONSAI_URL}
  • application-heroku.yml文件,对环境变量的引用${JDBC_DATABASE_URL}, ${JDBC_DATABASE_USERNAME}, ${JDBC_DATABASE_PASSWORD}, 没有被创建,唯一被创建的是DATABASE_URL包含 withpostgres://[generated-user]:[generated-secret]@[generated-url]:5432/[generated-dbname]
  • 上错了
    • 没有开始jdbc:
    • 环境变量名称与上面定义的不同DATABASE_URL(已创建)不等于JDBC_DATABASE_URL,并且${JDBC_DATABASE_USERNAME},${JDBC_DATABASE_PASSWORD}未创建。然后我的解决方法是在Herokusettings -> Config vars 上创建这些环境变量并正确编辑它们的值,比如......
    • 关键JDBC_DATABASE_URL价值jdbc:postgres://[url]:5432/[dbname]
    • 关键JDBC_DATABASE_USERNAME价值[username]
    • 关键JDBC_DATABASE_PASSWORD价值[password]
    • 或者您可以将其更改url: ${JDBC_DATABASE_URL}url: jdbc:${DATABASE_URL}(以前从未尝试过,对结果没有信心)。

推荐阅读