Привет, я получаю сообщение об ошибке при попытке развернуть мое приложение для сборки java maven на heroku

#maven #heroku #spring-boot #procfile

#maven #heroku #весенняя загрузка #procfile

Вопрос:

Привет, я немного новичок в heroku. Приложение отлично работает на локальном, но на heroku я получаю эту ошибку при попытке выполнить запрос rest на контроллере

pom.xml

 <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>

  <groupId>org.springframework</groupId>
  <artifactId>gs-maven</artifactId>
  <version>0.1.0</version>
  <packaging>war</packaging>

  <name>testing</name>
  <url>http://maven.apache.org</url>

  <properties>
    <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
  </properties>

  <dependencies>
    <dependency>
      <groupId>junit</groupId>
      <artifactId>junit</artifactId>
      <version>3.8.1</version>
      <scope>test</scope>
    </dependency>
        <dependency>
            <groupId>joda-time</groupId>
            <artifactId>joda-time</artifactId>
            <version>2.2</version>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
            <version>1.4.1.RELEASE</version>
        </dependency>
        <dependency>
            <groupId>javax.ws.rs</groupId>
            <artifactId>javax.ws.rs-api</artifactId>
            <version>2.0</version>
        </dependency>
        <dependency>
            <groupId>org.json</groupId>
            <artifactId>json</artifactId>
            <version>20160810</version>
        </dependency>
  </dependencies>

  <build>
        <plugins>
        <!--
            <plugin>
                <groupId>org.apache.maven.plugins</groupId>
                <artifactId>maven-shade-plugin</artifactId>
                <version>2.1</version>
                <executions>
                    <execution>
                        <phase>package</phase>
                        <goals>
                            <goal>shade</goal>
                        </goals>
                        <configuration>
                            <transformers>
                                <transformer implementation="org.apache.maven.plugins.shade.resource.ManifestResourceTransformer">
                                    <mainClass>hello.Application</mainClass>
                                </transformer>
                            </transformers>
                        </configuration>
                    </execution>
                </executions>
            </plugin>
            -->
            <plugin>
                <groupId>org.apache.maven.plugins</groupId>
                <artifactId>maven-war-plugin</artifactId>
                <version>2.6</version>
                <configuration>
                    <warSourceDirectory>src/main/jwebapp</warSourceDirectory>
                    <warName>gs-maven-0.1.0</warName>
                    <failOnMissingWebXml>false</failOnMissingWebXml>
                    <processTypes>
                        <web>
                            java $JAVA_OPTS -cp target/classes:target/dependency/* Application
                        </web>
                    </processTypes>
                </configuration>
            </plugin>
        </plugins>
    </build>


</project>
  

журналы ошибок здесь
ЖУРНАЛЫ

 2016-10-22T07:30:13.637732 00:00 heroku[web.1]: State changed from starting to c
rashed

2016-10-22T07:30:13.637732 00:00 heroku[web.1]: State changed from crashed to st
arting

2016-10-22T07:30:18.085285 00:00 heroku[web.1]: Starting process with command `j
ava -Dserver.port=17355 $JAVA_OPTS -jar target/*.jar`

2016-10-22T07:30:19.552462 00:00 heroku[web.1]: Process exited with status 1

2016-10-22T07:30:19.559097 00:00 heroku[web.1]: State changed from starting to c
rashed

2016-10-22T07:30:19.499662 00:00 app[web.1]: Create a Procfile to customize the
command used to run this process: https://devcenter.heroku.com/articles/procfile

2016-10-22T07:30:19.503097 00:00 app[web.1]: Setting JAVA_TOOL_OPTIONS defaults
based on dyno size. Custom settings will override them.

2016-10-22T07:30:19.503942 00:00 app[web.1]: Error: Unable to access jarfile tar
get/*.jar

2016-10-22T07:30:39.331500 00:00 heroku[router]: at=error code=H10 desc="App cra
shed" method=GET path="/" host=waisserver.herokuapp.com request_id=4249b569-93d2
-4257-adc2-3ddf8577e4fd fwd="188.172.153.178" dyno= connect= service= status=503
 bytes=
  

Комментарии:

1. Можете ли вы показать нам свой Procfile?

2. Привет, на самом деле, возможно, проблема в том, что я не думаю, что у меня есть файл proc, действительно ли он мне нужен, поскольку в некоторых руководствах это не упоминается

3. Я развертываю это с помощью github

Ответ №1:

Спасибо, Алекс. Руководство по загрузке Spring сработало. Для записи мой pom.xml сейчас файл выглядит так, и мне даже не нужен был procfile.

POM.XML

 <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>

  <groupId>org.springframework</groupId>
  <artifactId>gs-maven</artifactId>
  <version>0.1.0</version>
  <packaging>jar</packaging>

  <name>testing</name>
  <url>http://maven.apache.org</url>

  <properties>
    <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
  </properties>

<parent>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-parent</artifactId>
    <version>1.4.1.RELEASE</version>
</parent>  

  <dependencies>
    <dependency>
      <groupId>junit</groupId>
      <artifactId>junit</artifactId>
      <version>3.8.1</version>
      <scope>test</scope>
    </dependency>
        <dependency>
            <groupId>joda-time</groupId>
            <artifactId>joda-time</artifactId>
            <version>2.2</version>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
            <version>1.4.1.RELEASE</version>
        </dependency>
        <dependency>
            <groupId>javax.ws.rs</groupId>
            <artifactId>javax.ws.rs-api</artifactId>
            <version>2.0</version>
        </dependency>
        <dependency>
            <groupId>org.json</groupId>
            <artifactId>json</artifactId>
            <version>20160810</version>
        </dependency>
  </dependencies>

  <build>
        <plugins>
        <!--
            <plugin>
                <groupId>org.apache.maven.plugins</groupId>
                <artifactId>maven-shade-plugin</artifactId>
                <version>2.1</version>
                <executions>
                    <execution>
                        <phase>package</phase>
                        <goals>
                            <goal>shade</goal>
                        </goals>
                        <configuration>
                            <transformers>
                                <transformer implementation="org.apache.maven.plugins.shade.resource.ManifestResourceTransformer">
                                    <mainClass>hello.Application</mainClass>
                                </transformer>
                            </transformers>
                        </configuration>
                    </execution>
                </executions>
            </plugin>
            <plugin>
                <groupId>org.apache.maven.plugins</groupId>
                <artifactId>maven-war-plugin</artifactId>
                <version>2.6</version>
                <configuration>
                    <warSourceDirectory>src/main/jwebapp</warSourceDirectory>
                    <warName>gs-maven-0.1.0</warName>
                    <failOnMissingWebXml>false</failOnMissingWebXml>
                    <processTypes>
                        <web>
                            java $JAVA_OPTS -cp target/classes:target/dependency/* Application
                        </web>
                    </processTypes>
                </configuration>
            </plugin>
            -->
            <plugin>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-maven-plugin</artifactId>
        </plugin>
        </plugins>
    </build>


</project>
  

Ответ №2:

В ваших журналах мы видим следующее:

Запуск процесса с помощью команды java -Dserver.port=17355 $JAVA_OPTS -jar target/*.jar

Ошибка: не удается получить доступ к целевому файлу jarfile / *.jar

heroku-maven-plugin

В прошлом я использовал только Procfile, но я вижу, что вы также можете использовать heroku-maven-plugin для указания команды запуска (документация heroku).

Я считаю, что вам нужно установить <processType> тег в heroku-maven-plugin , а не maven-war-plugin :

 <plugin>
  <groupId>com.heroku.sdk</groupId>
  <artifactId>heroku-maven-plugin</artifactId>
  <configuration>
    <processTypes>
      <web>java $JAVA_OPTS -cp target/classes:target/dependency/* Application</web>
    </processTypes>
  </configuration>
</plugin>
  

Затем выполните развертывание с помощью этой команды: mvn heroku:deploy -Dheroku.appName=myapp

Весенняя загрузка?

Кроме того, я вижу зависимость spring-boot-starter-web . Это приложение для весенней загрузки? Тогда у вас не должно быть maven-war-plugin и вместо этого создайте действительный архив spring-boot, используя spring-boot-maven-plugin (смотрите этот пример)

Если вы пойдете по пути spring-boot, вы могли бы создать его как Jar и использовать следующее Procfile (размещенное в корне вашего проекта с большой буквы P ):

 web: java $JAVA_OPTS -Dserver.port=$PORT -jar target/gs-maven-0.1.0.jar
  

Я думаю, вы можете указать подстановочный знак версии, поэтому вам не нужно постоянно изменять Procfile :

 web: java $JAVA_OPTS -Dserver.port=$PORT -jar target/gs-maven-*.jar
  

Взгляните на это:http://nicholaspaulsmith.com/spring-boot-on-heroku /

Комментарии:

1. Да, это проект spring boot. Мне было интересно, смогу ли я вообще не использовать procfile, но я попробую все

2. Большое спасибо. Руководство по загрузке Spring сработало. В итоге мне даже не нужно было создавать procfile. Мой rest api теперь работает нормально. Спасибо